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要 开发 Web 动 态 程序 , PHP 是 比较 理想 的 开发 语言 之 一 ,PHP 易于 使 用 、 功 能 强大 、 成 本 低廉 、 
安全 性 高 、 开 发 速度 快 且 执行 灵活 。 本 书 以 全 程 实例 为 目标 设计 ， 内 容 丰 富 ， 对 每 一 个 知识 点 都 进 
行 了 深入 详细 的 讲解 ， 图 文 并 茂 。 本 书 从 运行 环境 搭建 、PHP 的 基本 语法 和 规范 入 手 ， 由 浅 入 深 、 
循序 渐进 、 系 统 地 介绍 PHP 的 相关 技术 及 其 在 实际 Web 开 发 中 的 应 用 ， 即 针对 核心 动态 网 站 的 功能 
模块 开发 进行 细致 的 讲解 ， 一 步 一 步 地 引导 读者 掌握 PHP 开 发 的 全 部 知识 体系 结构 。 

本 书 共 分 为 10 章 ， 在 内 容 编排 上 独具匠心 ， 各 章节 的 知识 点 相互 独立 且 前 后 贯穿 有 序 。 每 章 
的 实例 均 符 合 所 讲解 的 知识 点 ， 实 现 了 实践 与 理论 相 结合 , 会 对 读者 在 学 习 中 的 思路 整理 、 开 发 创 
意 有 所 帮助 。 各 章节 的 内 容 如 下 : 

第 1 章 引 导读 者 进入 PHP 7.0 开 发 领域 了解 Web 开 发 所 需要 的 各 种 构件 ,掌握 基于 数据 库 的 动 
态 网 站 运行 原理 ， 以 及 PHP 的 功能 、 开 发 优势 和 发 展 趋势 。 在 Windows 系 统 下 独立 安装 各 种 PHP 所 
需要 的 开发 环境 ， 掌 握 phpMyAdmin 数 据 库 的 管理 方法 。 

第 2 章 着 重 以 小 实例 的 形式 介绍 PHP 的 基本 语法 ,包括 语言 风格 、 数 据 类 型 、 变 量 、 常 量 、PHP 
运算 符 和 表达 式 的 内 容 ， 同时， 还 会 介绍 PHP 的 语言 结构 ， 包 括 条 件 语 句 、 循 环 语句 等 流程 控制 结 
构 ， 以 及 函数 声明 与 应 用 的 各 个 环节 ; 另外 ，PHP 的 数组 与 数据 结构 的 应 用 也 有 所 涉及 。 

第 3 章 介绍 在 Dreamweaver 软 件 下 实现 成 绩 查询 系统 动态 功能 的 开发 ， 重 点 介绍 使 用 
Dreamweaver 进 行 PHP 开 发 的 流程 ， 搭 建 PHP 动 态 系统 开发 的 平台 ， 检 查 数据 库 记 录 和 编辑 记录 的 
常见 操作 。 

第 4 章 介绍 全 程 实例 : 用 户 管理 系统 的 开发 ， 按 照 软件 开发 的 基本 过 程 ， 以 系统 的 需求 分 析 、 
数据 库 设计 和 系统 的 详细 设计 为 基本 开发 步骤 , 详细 介绍 用 户 管 理 系 统 开 发 的 全 部 过 程 。 通过 对 用 
户 注册 信息 的 统计 , 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ; 通过 用 户 权限 的 设置 ， 可 以 限制 其 对 网 
站 页 面 的 访问 权限 。 

第 5 章 详 细 介 绍 全 程 实例 : 新 闻 管 理 系统 的 实现 方法 。 新 闻 管理 系统 主要 实现 对 新 闻 的 分 类 和 
发 布 , 模拟 一 般 新 闻 媒介 发 布 新 闻 的 过 程 。 新 闻 管理 系统 的 作用 就 是 在 网 上 传播 信息 ,通过 对 新 闻 
的 不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 业 状况 以 及 其 他 需要 了 解 的 一 些 知识 。PHP 实 现 这 些 功 
能 相对 比较 简单 ， 涉 及 的 主要 操作 有 实现 访问 者 的 新 闻 查询 功能 ， 完 成 系统 管理 员 对 新 闻 的 新 增 、 
修改 、 删 除 功 能 。 

第 6 章 介绍 全 程 实例 : 在 线 投票 管理 系统 的 开发 方法 。 一 个 投票 管理 系统 可 分 为 3 个 主要 功能 
模块 : 投票 功能 、 投 票 处 理 功能 以 及 显示 投票 结果 功能 。 投票 管 理 系统 首先 给 出 投票 选 题 ， 即 供 投 

票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 投 票 处 理 功 能 被 激活 ， 从 而 对 服务 器 传送 过 
来 的 数据 做 出 相应 的 处 理 。 先 判断 用 户 选择 的 是 哪 一 项 , 并 累计 相应 项 的 字段 值 , 然后 对 数据 库 进 
行 更 新 ， 最 后 将 投票 的 结果 显示 出 来 。 
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第 7 章 介 绍 全 程 实例 : 留言 簿 管理 系统 的 制作 方法 。 网 站 留言 簿 管理 系统 的 功能 主要 是 实现 网 
站 的 访问 者 和 网 站 管理 者 的 一 个 互动 , 访问 者 可 以 向 网 站 管理 者 提出 任何 意见 和 信息 , 网 站 管理 者 
可 以 在 后 台 及 时 回复 。 主 要 涉及 的 技术 有 数据 库 留言 信息 的 插入 ， 回 复 和 修改 信息 的 更 新 等 操作 ， 
在 设置 信息 的 回复 时 间 时 还 会 涉及 一 些 关 于 PHP 时 间 函 数 的 设置 问题 。 

第 8 章 介 绍 全 程 实例 : 网 站 论坛 管理 系统 的 开发 。 论 坛 管理 系统 的 主要 功能 是 通过 在 计算 机 上 
运行 服务 软件 ， 允 许 用 户 使 用 终端 程序 ， 通 过 Internet 来 进行 连接 ， 执 行 用 户 消息 之 间 的 交互 功能 ， 
支持 用 户 建 帖 、 回 复 、 搜 索 、 查 看 等 功能 。 主 要 设计 是 网 站 论坛 管理 系统 的 首页 ， 用 户 既 可 以 在 这 
里 发 布 讨论 的 主题 ， 也 可 以 回复 主题 ， 版 主 还 可 以 对 自己 的 栏目 或 版 块 进行 修改 、 删 除 等 操作 。 

第 9 章 介绍 全 程 实例 ;翡翠 电子 商城 前 台 的 开发 。 网 上 购物 系统 通常 有 产品 发 布 、 订 单 处 理 、 
购物 车 等 动态 功能 。 网 站 管理 者 登录 后 台 管 理 ， 即 可 进行 商品 维护 和 订单 处 理 操作 。 从 技术 角度 来 
说 主要 是 通过 “购物 车 ”来 实现 电子 商务 功能 。 网 络 商店 是 比较 庞大 的 系统 ， 必 须 拥有 会 员 系统 、 
查询 系统 、 购 物流 程 、 会 员 服 务 等 功能 模块 ， 这 些 系统 通过 用 户 身份 的 验证 统一 进行 使 用 ， 从 技术 
角度 上 来 分 析 难点 就 在 于 数据 库 中 各 系统 数据 表 的 关联 。 本 实例 介绍 使 用 PHP 进 行 网 上 购物 系统 前 
台 开发 的 方法 , 系统 地 介绍 翡翠 电子 商城 的 前 台 设 计 ， 数据 库 的 规划 以 及 常用 的 几 个 功能 模块 前 台 
的 开发 。 

第 10 章 介绍 全 程 实例 : 翡翠 电子 商城 后 台 。 翡 翠 电 子 商城 前 台 主 要 实现 的 是 网 站 针对 会 员 的 
所 有 功能 ,包括 会 员 注 册 、 购 物 车 以 及 留言 功能 的 开发 , 但 一 个 完善 的 网 上 购物 系统 并 不 只 是 为 用 
户 提供 注册 功能 , 还 应 为 网 站 所 有 者 提供 一 个 功能 齐全 的 后 台 管理 功能 。 网 站 所 有 者 登录 后 台 应 该 
可 以 发 布 新 闻 公 告 、 管 理会 员 注册 信息 、 回 复 留言 、 维 护 商品 以 及 处 理 订 单 等 。 

本 书 配套 素材 和 源 代码 下 载 地 址 : https://pan.baidu.com/s/1otuYjd99q|_-t2RL_dt-cA ( 注 
意 区 分 数字 与 字母 大 小 写 ) ， 还 可 以 扫描 下 面 的 二 维 码 进行 下 载 。 

















如 果 下 载 有 问题 , 请 发 送 电子 邮件 至 booksaga@126.com, 邮件 主题 设置 为 “ 求 PHP 7.0+MySQL 
网 站 开发 全 程 实例 源 代 码 ”。 

本 书 由 于 荷 云 编 苦 ， 另 外 ， 陈 益 材 、 张 冰 、 丰 捷 梅 、 张 慧 、 曹 雪松 、 辛 植 、 梁 廷 森 、 谷 庆 霄 、 
原野 、 王 颖 、 连 兴 博 、 王 国 华 、 张 春 森 等 也 参与 了 编写 工作 ， 他 们 均 为 多 年 从 事 商业 网 站 建设 的 资 
深 网 页 设计 师 。 由 于 作者 水 平 有 限 ， 疏 漏 之 处 在 所 难免 ， 欢 迎 各 位 读者 与 专家 批评 指正 。 
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第 章 


PHP 7.0 开 妈 环境 的 配置 


PHP 是 一 种 多 用 途 脚本 语言 ， 尤 其 适合 于 Web 应 用 程序 开发 。 使 用 PHP 强 大 的 扩展 性 ， 可 以 
在 服务 端 连接 Java 应 用 程序 ， 还 可 以 与 .NET 建 立 有 效 的 沟通 甚至 更 广阔 的 扩展 ， 从 而 可 以 建立 一 
个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 资源 。 并 且 ， 开 源 和 跨 平台 的 特性 使 得 使 用 
PHP 架 构 能 够 快速 、 高 效 地 开发 出 可 移植 的 、 跨 平台 的 、 具 有 强大 功能 的 企业 级 Web 应 用 程序 。 
在 使 用 PHP 进 行 网 站 开发 之 前 ， 需 要 在 操作 系统 上 搭建 一 个 适合 PHP 开 发 的 操作 平台 。 使 用 
Windows 自 带 的 IIS 服 务 器 或 者 单独 安装 一 个 Apache 服 务 器 都 可 以 实现 PHP 的 解析 运行 ， 对 于 刚 入 
门 的 新 手 而 言 ，PHP 的 开发 环境 推荐 使 用 Apache (服务 器 ) 十 Dreamweaver (网 页 开发 软件 ) 
+MySQL (数据 库 ) 组 合 ， 本 章 将 重点 介绍 PHP 网 站 开发 环境 的 配置 。 对 于 初学 者 建议 直接 安装 
XAMPP 集 成 环境 进行 学 习 。 

本 章 的 学 习 重 点 
PHP 7.0 的 基础 知识 
集成 环境 XAMPP 的 安装 和 使 用 
PHP 环 境 的 安装 与 配置 
PHP 的 开发 工具 
使 用 Dreamweaver 开 发 PHP 的 配置 
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医 世 国 Php 7.0 开 发 环境 与 特性 


PHP 全 名 为 Personal Home Page， 是 非常 普及 、 应 用 比较 广泛 的 Web 开 发 语言 之 一 ， 其 语法 混 
合 了 C、Java、Perl 以 及 PHP 自 创新 的 语法 。 它 具有 开放 的 源 代码 ， 多 种 数据 库 的 支持 ， 并 且 支 持 跨 
平台 的 操作 和 面向 对 象 的 编程 ， 而 且 有 完全 免费 的 特点 。 本 节 首 先 介绍 一 下 PHP 7.0 版 本 的 一 些 基 
础 知识 和 新 特点 。 


1.1.1 ”PHP 网 站 运行 模式 


PHP 是 一 种 HTML 内 嵌 式 的 语言 。 与 微软 的 ASP 相 似 ， 都 是 一 种 在 服务 器 端 执 行 、 柑 入 HTML 
文档 的 脚本 语言 ， 语 言 的 风格 又 类 似 于 C 语 言 ， 现 在 被 很 多 的 网 站 编程 人 员 广 泛 地 应 用 。PHP 是 英 
文 “PHP: Hypertext Preprocessor”【〔 超 级 文本 预 处 理 语言 的 递归 缩写 ， 是 一 种 HTML 内 嵌 式 的 
语言 ， 在 服务 器 端 执行 的 嵌入 HTML 文 档 的 脚本 语言 ， 语 言 的 风格 类 似 于 C 语 言 ， 被 广泛 运用 于 动 
态 网 站 的 制作 中 。PHP 语 言 借鉴 了 C 和 Java 等 语言 的 部 分 语法 ， 并 有 自己 的 特性 ， 使 Web 开 发 者 能 
够 快速 地 编写 动态 生成 页 面 的 脚本 。 对 于 初学 者 而 言 ，PHP 的 优势 是 可 以 使 初学 者 快速 入 门 。 

如 图 1-1 所 示 为 PHP 的 运行 模式 。 PHP 还 具有 非常 强大 的 功能 , 所 有 的 CGI 或 者 JavaScript 的 功能 
PHP 都 能 实现 ， 而 且 支持 几乎 所 有 流行 的 数据 库 以 及 操作 系统 。 
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图 1-1 PHP 网 站 的 运行 模式 


1.1.2 PHP 的 发 展 历程 


PHP 最 初 只 是 简单 地 用 Perl 语 言 编写 的 程序 ， 用 来 统计 开发 者 自己 网 站 的 访问 量 。 后 来 又 用 C 
语言 重新 编写 ， 开 发 可 以 访问 数据 库 等 新 功能 ， 并 在 1995 年 发 布 了 PHP 1.0。2015 年 6 月 11 日 ，PHP 
官网 发 布 消息 ， 正 式 公 开发 布 PHP 7 第 一 版 的 alpha 版 本 ，PHP 7.0 正 式 版 本 的 发 布 ， 标 志 着 一 个 全 
新 的 PHP 时 代 的 到 来 。 它 的 核心 是 Zend 引 擎 ，PHP 的 发 展 主要 经 历 了 以 下 8 个 阶段 。 

第 一 阶段 : 在 1994 年 ，Rasmus Lerdorf 首 次 开发 出 了 PHP 程 序 设 计 语言 。1995 年 6 月 ，Rasmnus 
Lerdorf 在 Usenet 新 闻 组 comp.infosystems.www.authoring.cgi 上 发 布 了 PHP 1.0 声 明 。 在 这 个 早期 版 本 
中 ， 提 供 了 访客 留言 本 、 访 客 计 数 器 等 简单 的 功能 。 
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第 二 阶段 : 1995 年 ，PHP 的 第 二 版 问世 ， 定 名 为 PHP/FI (Form Interpreter) 。 在 这 一 版 本 中 加 
入 了 可 以 处 理 更 复杂 的 嵌入 式 标签 语言 的 解析 程序 ， 同 时 加 入 了 对 数据 库 MySQL 的 支持 。 自 此 黄 
定 了 PHP 在 动态 网 页 开发 上 的 影响 力 。 自 从 PHP 加 入 了 这 些 强大 的 功能 ， 它 的 使 用 量 猛 增 。 据 初步 
统计 ， 在 1996 年 底 ， 有 15000 个 Web 网 站 使 用 了 PHP/FI， 而 在 1997 年 中 期 ， 这 一 数字 超过 了 50000。 

第 三 阶段 : PHP 前 两 个 版 本 的 成 功 , 让 PHP 的 设计 者 和 使 用 者 对 PHP 的 未 来 充满 了 信心 。 在 1997 
年 ， PHP 开发 小 组 又 加 入 了 Zeev Suraski 及 Andi Gutmans 两 个 程序 设计 师 ， 他 们 自愿 重新 编写 了 PHP 
底层 的 解析 引擎 ,还 有 很 多 其 他 人 也 自愿 加 入 了 PHP 相 关 功 能 的 开发 工作 ， 从 此 PHP 成 为 真正 意义 
上 的 开源 项 目 。 

第 四 阶段 : 在 1998 年 6 月 ， 发 布 了 PHP 3.0 声 明 。 在 这 一 版 本 中 PHP 可 以 跟 Apache 服 务 器 紧密 地 
结合 ; 它 还 可 以 不 断 地 更 新 来 加 入 新 的 功能 ; 并 且 它 几乎 支持 所 有 主流 与 非 主 流 数据 库 ; 而 且 拥有 
非常 高 的 执行 效率 ， 这 些 优势 使 在 1999 年 使 用 PHP 的 网 站 超过 了 150000 个 。 

第 五 阶段 : PHP 经 过 了 3 个 版 本 的 演化 ， 已 经 成 为 一 种 非常 强大 的 Web 开 发 语言 。 这 种 语言 非 
常 易 用 , 它 还 拥有 一 个 强大 的 类 库 , 而 且 类 库 的 命名 规则 也 十 分 规范 ， 就 算 对 一 些 函 数 的 功能 不 了 
解 ， 也 可 以 通过 函数 名 猜测 出 来 。 这 使 得 PHP 十 分 容易 学 习 ， 而 且 PHP 程 序 可 以 直接 使 用 HTML 编 
辑 器 来 处 理 ， 因 此 ，PHP 变 得 非常 流行 ， 有 很 多 大 的 门户 网 站 都 使 用 了 PHP 作 为 自己 的 Web 开 发 语 
言 ， 例 如 门户 网 站 新 浪 网 等 。 

第 六 阶段 : 在 2000 年 5 月 推出 了 PHP 划 时 代 的 版 本 一 一 PHP 4。 使 用 了 一 种 “编译 一 执行 ” 模 
式 ， 核 心 引擎 更 加 优越 ， 提 供 了 更 高 的 性 能 ， 而 且 还 包含 了 其 他 一 些 关键 功 能 ， 比 如 : 支持 更 多 的 
Web 服 务 器 、HTTP Sessions 支 持 、 输 出 缓存 、 更 安全 地 处 理 用 户 输入 的 方法 和 一 些 新 的 语言 结构 。 

第 七 阶段 : 2004 年 ?月 ，PHP 5 正式 版 本 的 发 布 ， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。 它 的 核 
心 是 第 二 代 Zend 引 擎 ， 并 引入 了 对 全 新 的 PECL 模 块 的 支持 。 

第 八 阶段 PHP 目 前 的 版 本 是 PHP 7.0 在 编写 本 书 时 ) ， 在 PHP 5.6 基 础 上 进行 了 进一步 的 改 
进 ， 功 能 更 强大 ， 执 行 效率 更 高 。 本 书 将 以 PHP 7.0 版 本 讲解 PHP 的 实用 技能 。 





1.1.3 “PHP 语言 的 优势 


与 其 他 的 编程 语言 相 比 ， 用 PHP 做 出 的 动态 页 面 是 将 程序 嵌入 到 HTML 文 档 中 去 执行 ， 执 行 效 
率 比 完全 生成 HTML 标 记 的 CGI 要 高 许多 ， 与 同样 是 嵌入 到 HTML 文 档 的 脚本 语言 JavaScript 相 比 ， 
PHP 在 服务 器 端 执行 ， 充 分 利用 了 服务 器 的 性 能 ，PHP 执 行 引擎 还 会 将 用 户 经 常 访 问 的 PHP 程 序 驻 
留 在 内 存 中 , 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 编译 程序 , 只 要 直接 执行 内 存 中 的 代码 
就 可 以 了 ， 这 也 是 PHP 高 效率 的 体现 之 一 。PHP 语 言 的 优势 具体 可 以 体现 在 以 下 7 个 方面 。 

1. 源 代码 完全 开放 

所 有 的 PHP 源 代码 都 可 以 得 到 。 读 者 可 以 通过 Internet 获 得 需要 的 源 代码 ， 快 速 修改 利用 。 

2. 完全 免费 ， 市 场 占有 率 较 高 

和 其 他 技术 相 比 , PHP 本 身 是 免费 的 。 读者 使 用 PHP 进 行 Web 开 发 无 须 支 付 任何 费用 。 基于 此 ， 
目前 PHP 在 网 站 开发 语言 市 场 上 占有 率 是 比较 高 的 ， 如 图 1-2 所 示 。 
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图 1-2 W3Techs.com 网 站 发 布 的 统计 信息 
3. 语法 结构 简单 


因为 PHP 结 合 了 C 语 言 和 Perl 语 言 的 特色 ， 编 写 简单 ， 方 便 易 懂 ， 可 以 被 嵌入 到 HTML 语 言 中 。 
相对 于 其 他 语言 ，PHP 编 辑 简单 ， 实 用 性 强 ， 更 适合 初学 者 。 


4. 跨 平 台 性 强 

由 于 PHP 是 运行 在 服务 器 端的 脚本 ， 因 此 可 以 运行 在 UNIX、Linux、Windows 下 。 

5. 执行 效率 高 

PHP 消 耗 相当 少 的 系统 资源 ， 并 且 程序 开发 快 、 运 行 快 。PHP 7 版 本 比 PHP 5 的 版 本 速度 还 要 
快 两 倍 。 

6. 强大 的 数据 库 支 持 

支持 目前 所 有 的 主流 和 非 主流 数据 库 , PHP 的 应 用 对 象 非常 广泛 。 目 前 公认 比较 好 的 开发 方案 
是 使 用 PHP+MySQL 的 组 合 开发 动态 网 站 。 

7. 面向 对 象 

在 PHP 5 以 后 的 版 本 , 面向 对 象 都 有 了 很 大 的 改进 , 现在 PHP 完 全 可 以 用 来 开发 大 型 商业 程序 。 


1.1.4 PHP 7 的 新 特性 


随 着 MySQL 数 据 库 的 发 展 ，PHP 5.0 以 后 的 版 本 (包括 PHP 7.0) 都 绑 定 了 新 的 MySQLi 扩 展 模 
块 ， 提 供 了 一 些 更 加 有 效 的 方法 和 实用 工具 ， 用 于 处 理 数据 库 操作 : 添加 了 面向 对 象 的 PDO (PHP 
Data Objects) 模块 ， 提 供 了 另外 一 种 数据 库 操作 的 方案 ， 统 一 数据 库 操作 的 API; 改进 了 创建 动态 
图 片 的 功能 ， 目 前 能 够 支持 多 种 图 片 格式 〈 如 PNG、GIF、TIF、JPEG 等 ) ; 已 经 内 置 了 对 GD2 库 的 
支持 ， 因 此 安装 GD2 库 (主要 是 在 UNIX 系 统 中 ) 也 不 再 是 难事 ， 这 使 得 图 像 处 理 十 分 简单 和 高 效 。 
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PHP 7.0.0 Alpha 1 使 用 新 版 的 ZendEngine 引 擎 ， 带 来 了 许多 新 的 特性 : 

(1) 全 方位 性 能 提升 : PHP 7 比 PHP 5.6 性 能 提升 了 两 倍 。 

(2) 全 面 一 致 的 64 位 支持 。 

(3) 以 前 的 许多 致命 错误 ， 现 在 改 成 抛 出 异常 。 

(4) 移 除了 一 些 老 的 不 再 被 支持 的 SAPI( 服 务 器 端 应 用 编程 端口 ) 和 扩展 。 
(5) 新 增 了 空 值 合 并 运算 符 。 

(6) 新 增 了 组 合 比 较 运 算 符 。 

(7) 新 增 了 函数 的 返回 类 型 声明 。 

(8) 新 增 了 标量 类 型 声明 。 

(9) 新 增 了 匿名 类 。 


蔚 下 对 集成 环境 XAMPP 的 安装 和 使 用 


对 于 初学 者 而 言 ， 不 需要 浪费 太 多 时 间 进 行 单独 环境 的 配置 和 安装 ， 特 别 推荐 初学 者 单独 下 
载 集成 环境 一 次 性 安装 到 位 ， 开 始 具 体 的 PHP 程 序 开发 ， 这 里 推荐 使 用 集成 环境 XAMPP。XAMPP 
(Apache+MySQL+PHP+PERL) 是 一 个 功能 强大 的 建站 集成 软件 包 。 这 个 软件 包 原 来 的 名 字 是 
LAMPP， 为 了 避免 误解 ， 最 近 的 几 个 版 本 就 改名 为 XYAMPP 了 。 它 可 以 在 Windows、Linux、Solaris 
三 种 操作 系统 下 安装 使 用 ， 支 持 多 种 语言 ， 如 英文 、 简 体 中 文 、 繁 体 中 文 、 韩 文 、 俄 文 、 日 文 等 。 





1.2.1 XAMPP 集 成 套件 的 下 载 安 装 


XAMPP 也 是 笔者 用 到 现在 为 止 感觉 比较 好 用 的 一 款 Apache+MySQL+PHP 套 件 , 同时 支持 Zend 
Optimizer， 支 持 插件 的 安装 ， 编 写本 书 时 XAMPP 的 最 新 版 本 是 1.8.1。 

下 载 的 方法 如 下 : 

步骤 01 和 打开 浏览 器 ， 输入 官方 网 址 (https://www.apachefriends.org/download.html ) ， 按 回 
车 键 后 ， 进 入 到 下 载 页 面 ， 如 图 1-3 所 示 。 


Db ©O Dre Cotoss yaMpp + [Ee 
Download 






lal Apache distibuion cortainng MaraDB.PHP and Perl Just 
saber K's that easy. 


踢 XAMPP for Windows 5.5.38, 5.6.28 & 7.0.13 
Version necksum au 

nd5 ah Ee 
ms shet om OSXFA 
mas sha1 [ET Add-ons and Themes 


图 1-3 进入 下 载 页 面 
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步 又 024 单 击 页 面 上 “XAMPP for Windows (适用 于 Windows 的 XAMPP ) ”的 7.0.13/PHP 
7.0.13 (使 用 PHP 7 版 本 ) 选项 后 面 的 Download(32bit) 下 载 链接 ， 即 可 开始 下 载 。XAMPP 是 完全 免 
费 的 ， 并 且 遵 循 GNU 通 用 公众 许可 ，XAMPP 目 前 包含 的 功能 模块 和 版 本 分 别 如 下 : 


Apache 2.4.23 

MariaDB 10.1.19 

PHP 7.0.13 

phpMyAdmin 4.5.1 

OpenSSL 1.0.2 

XAMPP Control Panel 3.2.2 
Webalizer 2.23-04 

Mercury Mail Transport System 4.63 
FileZilla FTP Server 0.9.41 

Tomcat 7.0.56 (with mod_proxy_ajp as connector) 
Strawberry Perl 7.0.56 Portable 


XAMPP 的 安装 过 程 很 简单 ， 解 压 包 等 就 更 简单 一 些 。 下 载 的 安装 包 有 122.7MB 大 小 ， 如 图 1-4 
所 示 。 


+ TT ， 7 | 有 开 85 本 


empo winda 7 1-VCTS rotoler ene oN iS Fn 





图 1-4 下 载 的 安装 软件 
在 Windows 10 操 作 系统 中 安装 XAMPP 的 步骤 如 下 : 
步 又 014 安装 时 最 好 放置 到 D 盘 ， 不 建议 放 到 系统 盘 中 ， 尤 其 是 早期 的 XAMPP 版 本 ， 可 能 


默认 安装 在 Program Files 下 ， 这 样 在 Windows 10 中 可 能 需要 修改 写 入 权限 ， 下 载 后 先 安装 下 载 的 组 
件 ， 完 成 安装 之 后 切换 回 XAMPP 的 安装 步骤 ， 提 示 将 开始 安装 XAMPP 组 件 ， 如 图 1-5 所 示 。 


第 1 章 PHP 7.0 开发 环境 的 配置 








B setup 一 口 X 


Setup - XAMPP 


Welcome to the XAMPP Setup Wizard. 


人 binami 








《5ack Next> Cancel 
图 1-5 安装 面板 
步骤 024 单 击 “Next ( 下 一 步 ) ”按钮 ， 打 开 “Select Components (选择 安装 组 件 ) ”对 话 
框 ， 这 里 保持 默认 值 ， 即 色 选 所 有 组 件 进行 安装 ， 如 图 1-6 所 示 。 


© setup 一 口 3 


Select Components 


Select the components you want to instalt clear the components you do not want to instal Cick Next 
when you are ready to continue 


-MI Server 



































Mercury Mail Server 
Tomeat 
ogram Languages 
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KAMPP Instaler 一 一 一 一 -一 一 一 一 一 有 
| <Back | Next > Cancel 











图 1-6 选择 安装 的 组 件 


步骤 03 人 4 单 击 “Next (下 一 步 ) ”按钮 ,打开 “Installation folder (安装 文件 夹 ) ”对 话 框 ， 
这 里 选择 在 D 盘 下 安装 ， 如 图 1-7 所 示 。 
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Setup 一 口 x 
Installation folder 
Please. choose a folder to install XAMPP 
Selectafolder |D:wampp |] 要 

KAMPP Installer — 

< Back Nent> Cancel 
图 1-7 选择 安装 路 径 


Vista 以 上 操作 系统 用 户 请 注意 : 由 于 对 Vista 默 认 安 装 的 C:\Program Files 文 件 夹 没有 足够 的 写 


权限 ， 推 荐 为 XAMPP 安 装 创建 新 的 路 径 ， 如 D:\XAMPP 或 D:myfolderXAMPP。 


步骤 044 单 击 “Next( 下 一 步 ) ”按钮 , 打开 “Bitnami for XAMPP (开源 项 目 中 的 XAMPP ) ” 


对 话 框 ， 这 里 可 以 通过 单 击 网 站 链接 了 解 详细 的 XAMPP 内 容 ， 如 图 1-8 所 示 。 


Setup 一 口 居 
Bitnami for XAMPP 


Bitnami for XAMPP provides fee instalers that can install 
Drupal Joomlal WordPress and many other popular open 
source apps on top of your existing XAMPP instalation 


https://binami com/xampp 








Leam more about Bitnami for XAMPP 回 

















XAMPP Installer — - 一 
《Back Next> Cancel 








图 1-8 XAMPP 在 开源 平台 上 的 描述 链接 


步骤 054 单 击 “Next (下 一 步 ) ”按钮 ， 打开 “Ready to Install ( 准备 开始 安装 ) ”对 话 框 ， 


如 图 1-9 所 示 。 提 示 系 统 已 经 准备 好 ， 将 XAMPP 安 装 到 计算 机 上 。 
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Setup 一 口 2 


Ready to Install 


Setup is now ready to begin instaling XAMPP on your computer. 





KAMPP Installer 








< Back Next > Cancel 








图 1-9 准备 安装 对 话 框 


步骤 06 人 和 。 单 击 “Next (下 一 步 ) ”按钮 ， 开 始 安装 组 件 。 安 装 的 组 件 比较 多 ， 近 700MB， 
需要 耐心 等 上 几 分 钟 ， 安 装 的 过 程 提示 如 图 1-10 所 示 。 


回 seup = “BB “Xx | 





Welcome to XAMPP! 好 


XAMPP is an easy to install Apache distribution 
containing MySQL, PHP and Penl 


Installing 
Unpacking fles 


KAMPP Installer 





< Back Next> Cancel 








图 1-10 ”安装 过 程 提示 
步骤 07 色 安装 完成 后 ， 会 弹出 “Completing the XAMPP Setup Wizard (完成 XAMPP 的 安装 
向 导 ) ”对 话 框 ， 这 里 不 需要 进行 任何 的 操作 ， 以 前 的 版 本 就 需要 根据 提示 进行 一 些 设置 。 单 击 选 
中 “Do you want to start the Control Panel now? (你 是 否 要 开始 启动 控制 面板 ) ” 复 选 框 ， 如 图 1-11 
所 示 . 
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日 seup - 0O x 


Completing the XAMPP Setup Wizard 


Setup has fnished instaling XAMPP on your computer 
回 Do you want to start the Conkol Panel now? 


binami 
《Back Finish Cancel 


图 1-11 完成 安装 对 话 框 
步骤 08 4 到 这 里 XAMPP 就 安装 完成 了 ， 如 果 提 示 XAMPP 安 装 失败 ， 请 先 运行 安装 一 半 的 
XAMPP 目 录 下 的 却 载 文件 uninstall xampp.bat 执 行 一 次 清理 ， 然 后 重新 安装 即 可 。 单 击 “Finish ( 完 
成 ) ”按钮 ， 弹 出 选择 语言 对 话 框 ， 这 里 选择 美 版 ( 英语 版 ) ， 如 图 1-12 所 示 。 


Language 加 


© O 〇 




















XX Abort Save 
图 1-12 ”选择 语言 版 本 对 话 框 


步骤 09 人 单 击 “Save (保存 ) ”按钮 启动 XAMPP Control Panel (XAMPP 控 制 面板 ) ， 如 
图 1-13 所 示 。 





XAMPP Control Panel v3.2.2 【Compiled: Nov 12th 2015] 口 x 
XAMPP Control Panel v3.2.2 
Toaues 

Sevice Module 。 PiDls) Portts) Actions 
Apache Start S| | confg || Logs 画 shel 
MysSQL Start Admin Config Logs 一 Explorer 
Fezma Sur corte | ae | | Bsemviees 
Mereuy sun | cme | | om ep 
Tomcat Sun) EB | Contg | an 下 


37 [nain] 。 there will be a security dialogue or things will break! So think ~ 
37 [nain] about ruming this application with adninistrator rights! 

37 [nain] XAPP Installation Directory: “d:\xanpp\” 

nain] Checking for prerequisites 

0 [nain] All prerequisites found 

0 fnain] 。 Initializing Modules 

[nain] Starting Check-Tiner 

[nain] Control Panel Ready 














图 1-13 打开 XAMPP 控制 面板 
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步骤 104 下 面 我 们 来 看 一 下 XAMPP 的 控制 面板 ， 单 击 面板 上 各 软件 组 件 后 面 的 Start 按 钮 ， 
弹出 “Windows 安 全 警报 ”对 话 框 ， 全 部 单 击 “ 允 许 访问 ”按钮 ， 如 图 1-14 所 示 。 


输 Windows 去 全 车流 x 





止 此 应 用 的 部 分 功能 





Windows 防火 墙 已 阻止 所 有 公用 网 阁 和 专用 网 络 上 的 mysqld.exe 的 枯 些 功能 . 
[和 
发 布 者 (P): 未 和 
路 径 (H): DiwampPNmysqlNbinvmysqld.exe 


允许 mysqld.exe 在 这 些 网 络 上 通信 : 
回 专用 网 络 ,例如 家 许 或 工作 网 络 (R) 


口 公 用 网 阁 ， 例 如 机 场 和 咖啡 关中 的 网 阁 (不 淮 荐 ,由 于 公用 网 阁 通 利安 全 性 很 小 或 者 根本 不 安全 ) 
yy 





四 ff 扣 内 取消 





图 1-14 设置 允许 访问 
步 又 114 启动 Apache、MySQL 两 个 核心 程序 ， 最 后 设置 完毕 的 对 话 框 如 图 1-15 所 示 。 从 中 
可 以 看 到 XAMPP 的 一 些 基本 控制 功能 ， 注 意 不 建议 把 这 些 功能 启动 运行 (开机 启动 ) ， 每 次 使 用 
时 就 当 一 个 软件 运行 即 可 ( 桌面 上 已 经 有 图 标 ) ， 这 样 在 不 使 用 XAMPP 时 更 节省 资源 。 





XAMPP Control Panel v3.2.2 [Compiled: Nov 12th 2015] 至 口 x 
XAMPP Control Panel v3.2.2 PF certo 
Modues 
Sevice Module PIDs) Pontls) Actions 本 
7684 
epee 4 aa [Sop | Form | [ cong | | as | | 硬 aw 
Mysal 3632 3306 Admn | confg (| Logs Explorer 
FieZia Start hrm Config Logs 时 sevices 
Mercury Start om Config Logs Hep 
Tomcat Start Ln Config Logs 由 Qut 
[nain] All prerequisites found ~ 


1 [nain] 。 Initializing Modules 

[nain] 。 Starting Check-Tiner 

[nain] Control Panel Ready 

[Apache] Attenpting to start Apache app... 
[Apache] Status change detected; running 

[nysql] Atteapting to start MySQL app... 

[nysal] Status change detected: running 





1-15 ”启动 组 件 服务 


步骤 12 人 启动 XAMPP 成 功 之 后 打开 浏览 器 ， 输 入 服务 器 默认 IP 地 址 : 127.0.0.1， 按 回 车 键 


之 后 默认 跳 转 到 http://127.0.0.1/dashboard/ 页 面 ， 如 图 1-16 所 示 ， 说 明 已 经 安装 成 功 ， 可 以 开始 使 用 
XAMPP. 
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XAMPP Apache + MariaDB + PHP + 
Perl 


Welcome to XAMPP for Windows 7.0.13 


You 





机 


图 1-16 XAMPP 欢迎 界面 











1.2.2 XAMPP 集 成 套件 的 使 用 


对 初学 者 而 言 ， 开发 后 的 PHP 网 站 程序 不 知道 要 放 在 哪里 ， 其 实 很 简单 ， 只 要 将 整个 网 站 程序 
放 在 htdocs 文 件 夹 下 就 可 以 进行 访问 了 , 如 图 1-17 所 示 。 同 样 要 将 数据 库 文件 放 在 Mysqldate 文 件 来 
下 ， 同 时 数据 库 的 连接 用 户 名 要 为 root， 密 码 为 空 (XAMPP 默 认 安 装 下 的 用 户 名 和 密码 ) 。 





pr © 
二 了 thn - esa 
* = v. 
i ee I ee 
国志 We = ed E23 i 3 
a 用 FRR a 





中 a 


加 pc-a0210mBTeT 
QH-20150829TPIA 
a 人 WR = 


图 1-17 网 站 所 放置 的 位 置 
XAMPP 安 装 完成 之 后 具体 的 使 用 方法 如 下 : 
(1) XAMPP 的 启动 路 径 
xampp\xampp-control.exe 


(2) XAMPP 服 务 的 启动 和 停止 脚本 路 径 





启动 Apache 和 MySQL: xampp\xampp_start.exe 
停止 Apache 和 MySQL: xampp\xampp_stop.exe 
启动 Apache: xampp\apache_start.bat 

停止 Apache: xampp\apache_stop.bat 

启动 MySQL: xampp\mysql] start.bat 

停止 MySQL: xampp\mysql stop.bat 

启动 Mercury 邮 件 服务 器 : xampp\mercury_start.bat 
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@ 设置 FileZilla FTP 服 务 器 : xampp\filezilla_setup.bat 
@ 启动 FileZilla FTP 服 务 器 : xampp\filezilla_start.bat 
@ 停止 FileZilla FTP 服 务 器 : xampp\filezilla_stop.bat 


(3) XAMPP 的 配置 文件 路 径 


Apache 基 本 配置 : xampp\apache\conf\httpd.conf 

Apache SSL: xampp\apache\conf\ssl.conf 

Apache Perl ( 仅 限 插 件 ) : xampp\apache\conf\perl.conf 
Apache Tomcat ( 仅 限 插件 ) : xampp\apache\conf\java.conf 
Apache Python ( 仅 限 插件 ) : xampp\apache\conf\python.conf 
PHP: xampp\php\php.ini 

MySQL: xampp\mysql\binmy.ini 

phpMyAdmin: xampp\phpMyAdmin\config.inc.php 

FileZilla FTP 服 务 器 : xampp\FileZillaFTP\FileZilla Server.xml 
Mercury 邮 件 服务 器 基本 配置 : xampp\MercuryMail\WMERCURY .INI 
Sendmail: xampp\sendmail\sendmail.ini 


(4) XAMPP 的 其 他 常用 路 径 
@ 网 站 根 目录 的 默认 路 径 : xampp\htdocs 
@ MySQL 数据库 默认 路 径 : xampp\mysql\data 


(5) 日 常 使 用 只 需要 使 用 XAMPP 的 控制 面板 即 可 ， 可 以 随时 控制 Apache、PHP、MySQL 以 
及 FTP 服 务 的 启动 和 终止 。 
(6) 附 XAMPP 的 默认 密码 


© MySsQL 
User: root Password: ( 空 ) 
@@ FileZilla FTP 


User: newuser Password: wampp 


User: anonymous Password: some(@mail.net 
®© Mercury 


Postmaster: postmaster (postmaster(@localhost) 
Administrator: Admin (admin(@localhost) 


TestUser: newuser Password: wampp 


@ WEBDAV 


User: wampp Password: xampp 


参照 上 文 对 XAMPP 的 安装 和 配置 完成 后 ， 就 可 以 安装 Dreamweaver 等 网 页 程序 编辑 软件 ， 进 
行 网 页 编程 测试 了 。 
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如 果 想 深入 了 解 PHP 运 行 环境 中 各 软件 的 配置 与 使 用 ， 可 以 从 互联 网 分 别 下 载 不 同 的 环境 软 
件 。PHP 的 运行 环境 需要 两 方面 的 支持 : 一 个 是 支持 PHP 运 行 的 Web 服 务 器 一 一 Apache， 而 在 具体 
安装 Apache 服 务 器 之 前 需要 在 运行 的 系统 上 安装 支持 Apache 服 务 器 的 Java 2 SDK; 另 一 个 是 PHP 运 
行 时 需要 加 载 的 主要 软件 包 ， 该 软件 包 主 要 是 解释 执行 PHP 页 面 的 脚本 程序 ， 如 解释 PHP 页 面 的 函 
数 等 。 

PHP 开 发 运行 环境 的 配置 步骤 如 图 1-18 所 示 。 


恒 一 步 ， 安装 Apache 服务 器 es 
他 二 步 : 安装 配置 PHP 
i 


第 三 步 :安装 配置 MySQL 数据 库 MySQL 








四 步 : 安装 phpMyAdmin 管理 数据 库 phpjMdAdih 
图 1-18 ”PHP 环境 配置 步骤 
有 关 配 置 步骤 中 软件 的 下 载 和 安装 本 书 不 做 具体 的 介绍 ， 感 兴趣 的 读者 可 以 自行 下 载 安装 测 
试 使 用 。 


蔚 瑟 对 PHP 的 开发 工具 


PHP 是 服务 器 端的 脚本 语言 , 需要 使 用 第 三 方 的 语言 开发 工具 来 编写 实现 , 目前 网 络 上 有 很 多 
免费 的 PHP 开 发 工具 ， 这 些 工 具 对 于 PHP 程 序 员 来 说 非常 好 用 ， 并 且 有 很 大 的 帮助 。 这 些 开发 工具 
各 有 千秋 ， 既 有 基本 的 脚本 编写 功能 ， 也 有 许多 高 级 功能 ， 想 找到 适合 的 却 不 是 一 件 容易 的 事 。 





1.3.1 专业 的 PHP 开 发 工具 


这 里 将 介绍 一 些 比 较 常 用 的 PHP 开 发 工具 ， 这 些 工 具 对 初学 者 十 分 有 用 。 同 样 ， 对 专业 PHP 程 
序 员 开发 特定 功能 所 需 的 高 端 工具 也 会 进行 介绍 。 

(1) SublimeText 开 发 工具 

该 工具 文件 较 小 但 功能 却 很 强大 ， 下 载 地 址 为 http://www.sublimetextcom/， 如 图 1-19 所 示 。 
SublimeText 是 非常 流行 的 编辑 器 之 一 ， 具 有 代码 高 亮 、 语 法 提示 、 自 动 完成 且 反 应 速度 快 的 特点 。 
该 编辑 器 软件 不 仅 具 有 华丽 的 界面 ， 还 支持 插件 扩展 机 制 ， 用 它 来 写 代 码 ， 绝 对 是 一 种 享受 。 
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amazing performance. 





| 











图 1-19 SublimeText 工 具 


(2) EditPlus 开 发 工具 

这 是 一 款 编写 PHP 时 使 用 非常 多 的 文本 编辑 器 ， 使 用 方便 ， 很 多 PHP 人 士 都 喜欢 用 它 。 下 载 地 
址 为 https:Wwww.editplus.com/， 如 图 1-20 所 示 。EditPlus 中 文 版 是 一 套 功能 强大 、 可 取代 记事 本 的 文 
字 编 辑 器 ， 拥 有 无 限制 的 撤销 与 重 做 、 英 文 拼写 检查 、 自 动 换行 、 列 数 标 记 、 搜 寻 取 代 、 同 时 编辑 
多 文件 、 全 屏幕 浏览 等 功能 。 它 比较 好 用 的 一 个 功能 就 是 可 以 监视 剪贴 板 ， 能 够 与 剪贴 板 同步 自动 
将 文字 粘贴 进 EditPlus 的 编辑 窗口 中 , 让 用 户 省 去 粘贴 的 步骤 。 另 外, 它 也 是 一 个 非常 好 用 的 HTML 
编辑 器 ， 除 了 支持 颜色 标记 、HTML 标 记 外 ， 同 时 还 支持 C、C++、Perl、Java。 另 外 ， 它 还 内 建 完 
整 的 HTML & CSS1 指 令 功 能 ， 对 于 习惯 用 记事 本 编辑 网 页 的 朋友 ， 它 可 帮 你 节省 一 半 以 上 的 网 页 
制作 时 间 ， 若 有 安装 IE 5.0 以 上 版 本 ， 它 还 会 结合 IE 浏览 器 于 EditPlus 窗 口中 ， 让 用 户 可 以 直接 预览 
编辑 好 的 网 页 。 





Et 地 


Editplus - text editor for Windows 








120 EditPlus 开发 I 具 
(3 ) Notepad++ 开 发 工具 
Notepad++ 是 一 款 非常 有 特色 的 编辑 器 ， 是 开源 软件 ， 可 以 免费 使 有 用， 下载 地 址 为 
https://notepad-plus-plus.org/， 如 图 1-21 所 示 。 
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1-21 Notepadt+ 开 发 工具 
这 款 编辑 器 的 功能 基本 和 EditPlus 差 不 多 ， 有 的 地 方 甚至 更 强大 ， 只 是 使 用 习惯 上 有 些 不 同 。 
@ 内 置 支持 多 达 27 种 语法 高 亮度 显示 ( 宫 括 各 种 常见 的 源 代 码 、 脚 本 ， 值 得 一 提 的 
是 ， 完 美 支持 .nfo 文 件 查看 ) ， 也 支持 自 定义 语言 ; 
@ 可 自动 检测 文件 类 型 ， 根据 关键 字 显 示 节 点 ， 节 点 可 自由 折 沾 /打开 ， 代 码 显示 得 
非常 有 层次 感 ! 这 是 此 软件 比较 有 特色 的 体现 之 一 ; 
@ 可 打开 双 窗 口 ， 在 分 窗口 中 又 可 打开 多 个 子 窗 口 ， 允 许 使 用 快捷 键 F11 切 换 全 屏 显 
示 横 式 ， 支 持 和 鼠标 滚轮 改变 文档 显示 比例 等 ; 
@ 提供 多 个 有 特色 的 功能 ， 如 邻 行 互 换 位 置 、 宏 功能 等 ， 虽然 现在 网 上 有 很 多 文件 
编辑 器 ， 这 个 却 是 不 可 多 得 的 一 款 ， 不 论 是 日 常 使 用 还 是 手写 编程 代码 ， 都 能 让 
你 体会 到 它 独 有 的 优势 和 方便 、 快 捷 的 功能 。 
(4) Eclipse PDT (PHP Development Tools ) 工具 
归属 于 Zend Studio 这 个 IDE 集 成 坏 境 ， 下 载 地 址 为 http://downloads.zend.com/pdt/3.2.0/， 官 网 如 
图 1-22 所 示 。 











zendguard = ps 





图 1-22 Zend 官网 下 载 


Eclipse 这 个 集成 开发 环境 只 要 有 插件 就 可 以 实现 相应 功能 。 PDT 这 个 工具 很 早 就 开始 进行 开发 
了 ，Zend Studio for Eclipse 就 是 基于 这 个 插件 的 ， 再 加 上 自 带 的 调试 器 。 也 可 以 在 Eclipse 上 使 用 这 
个 插件 ， 然 后 自己 再 去 选择 调试 器 来 配置 自己 的 开发 坏 境 。 至 于 怎么 配置 ， 大 家 可 以 自己 查阅 网 上 


16 


第 1 章 PHP 7.0 开 发 环境 的 配置 


的 攻略 ， 这 里 只 是 介绍 工具 ， 不 进行 详细 讲解 。 这 里 介绍 的 所 有 配置 包 都 是 Zend 开 发 的 ， 因 为 是 
免费 的 ， 所 入 使 用 时 自然 不 能 和 Zend Studio 相 比 。 

因为 是 在 Eclipse 上 安装 插件 自 定义 实现 ,不 必 为 PHP 开 发 再 安装 一 个 大 型 软件 , 所 以 还 是 有 很 
多 人 喜欢 用 此 工具 的 。 





1.3.2 ”适合 初学 者 的 开发 工具 


对 于 初学 者 而 言 ， 刚 开始 学 习 PHP 程 序 开发 时 既 要 考虑 网 页 布局 的 问题 ， 又 要 考虑 后 台 PHP 程 
序 的 执行 问题 ， 而 有 一 款 软件 Dreamweaver 是 所 见 即 所 得 ， 非 常 适合 初学 者 学 习 并 应 用 ， 到 2017 年 
已 经 出 到 了 Dreamweaver CC 2017 版 ， 本 书 建议 使 用 此 软件 进行 PHP 的 学 习 与 应 用 。Dreamweaver 
是 集 网 页 制作 和 网 站 管理 于 一 体 的 网 页 编辑 器 , 它 同时 也 是 针对 专业 网 页 设计 人 员 特 别 设计 的 可 视 
化 网 页 开发 工具 ， 利 用 它 可 以 轻而易举 地 制作 出 路 平台 、 路 浏览 器 、 充 满 动感 的 网 页 。 

Dreamweaver 软 件 可 以 很 方便 地 通过 互联 网 直接 下 载 安装 使 有 用， 下载 安 装 的 步骤 如 下 : 

步 又 014 登录 Adobe 公 司 的 官网 并 先 免费 注册 一 个 用 户 ， 登 录 的 网 址 为 
http://www.adobe.com/cn/， 如 图 1-23 所 示 。 





© 





图 1-23 登录 Adobe 官网 并 注册 用 户 


步骤 02C 单 击 页 面 右 上 角 的 “菜单 ”文字 链接 ， 人 产品 ” 
如 图 1-24 所 示 。 从 菜单 中 选择 “Creative Cloud ( 云 安装 包 ) ”， 之 所 以 选择 整个 云 安装 包 是 为 了 方 
便 软件 一 键 式 下 载 和 安装 。 


© 





图 1-24 从 菜单 中 选择 Creative Cloud ( 云 安装 包 ) 
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步骤 034 、 下 载 的 Creative Cloud( 云 安装 包 ) 非 常 小 , 双击 以 后 就 可 以 直接 从 云端 下 载 Creative 
Cloud ( 云 安装 包 ) 的 桌面 ， 如 图 1-25 所 示 。 








Adobe 安装 得 序 
正在 安装 creative Cloud 桌面 
97% 完 成 








1-25 下 载 并 安装 Creative Cloud 
步骤 044 安装 完成 后 , 启动 Creative Cloud ( 云 安装 包 )， 在 面板 中 有 Adobe 公 司 的 所 有 软件 ， 


根据 需要 我 们 直接 在 Dreamweaver CC(2017) 中 单 击 “ 试 用 ”按钮 ， 软 件 即 可 自行 安装 。 一 键 式 的 下 
载 安装 非常 方便 ， 如 图 1-26 所 示 。 


Creatve Ccud 一 二 





Apps 
加 Dreamweaver CC (2017) 
Photoshop CC (207) 
试用 
Lightroom CC (2015) 
四 
四 . 
试用 


1-26 安装 Dreamweaver CC(2017) 试 用 版 


第 一 次 启动 Dreamweaver CC 2017 后 ， 系 统 会 弹出 一 个 界面 预 置 对 话 框 。 利 用 该 界面 预 署 对 话 
框 ， 用 户 可 以 更 加 快速 地 查找 相关 内 容 ， 更 加 清晰 地 显示 上 下 文 以 及 焦点 ， 快 速 存 取 最 近 使 用 的 文 
档 和 教程 资源 。 

启动 Dreamweaver CC 2017 后 的 操作 界面 如 图 1-27 所 示 。 Dreamweaver CC 2017 的 操作 界面 主要 
由 以 下 几 个 部 分 组 成 : 菜单 栏 、 标 题 栏 、 工 具 栏 、 文 档 窗口 、 标 签 栏 、 属 性 设置 面板 以 及 多 个 浮动 
面板 。 在 本 小 节 中 将 简单 地 介绍 其 中 主要 的 部 分 ， 以 便 读者 先 对 Dreamweaver CC 2017 有 个 简单 的 
了 解 。 具 体 应 用 将 在 以 后 的 章节 中 进行 详细 的 介绍 。 
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PHP 电 子 商 务 网 站 


CT 











标签 栏 i me 攻 








属性 设置 而 要 ni 


图 1-27 Dreamweaver CC 2017 的 操作 界面 


区 使 用 Dreamweaver 开 发 PHP 的 配置 


Dreamweaver 这 套 软 件 提供 了 网 站 开发 的 集成 性 环境 ， 它 可 以 支持 不 同 服务 器 技术 ， 如 ASP、 
PHP、JSP 等 ， 建 立 动态 支持 数据 库 的 网 络 应 用 程序 ， 同 时 也 能 让 不 懂 程 序 代码 的 网 站 设计 人 员 或 
初学 者 在 不 用 撰写 程序 代码 的 情况 下 学 习 动 态 网 页 的 设计 。 


1.4.1 使 用 Dreamweaver 建 设 网 站 步骤 


在 开始 制作 网 站 之 前 ， 还 要 了 解 在 Dreamweaver CC 2017 中 的 网 页 设计 和 发 布 流程 。 它 可 以 分 
为 以 下 5 个 主要 步骤 。 

第 一 步 : 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 ， 针 对 的 是 什么 样 的 访问 者 ， 以 确定 网 页 中 
应 该 出 现 什 么 内 容 。 

第 二 步 : 建立 站 点 的 基本 结构 

在 Dreamweaver CC 2017 中 可 以 在 本 地 计算 机 上 建立 整个 站 点 的 框架 ， 并 在 各 个 文件 夹 中 合理 
地 安置 文档 。 Dreamweaver CC 2017 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 , 一 种 是 目录 结构 ， 
男 一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 了 本 地 站 点 并 生成 
了 相应 的 站 点 结构 ， 即 创建 了 可 以 进一步 编辑 的 各 种 文档 ， 在 其 中 可 以 编辑 文档 和 数据 。 

第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CC 2017 软 件 中 ， 就 可 以 进行 页 面 的 版 面 规划 设计 ， 利 用 强 
大 的 编辑 设计 功能 可 以 实现 各 种 复杂 的 表格 , 再 组 织 页 面 内 容 。 为 了 保持 页 面 的 统一 风格 可 以 利用 
模板 来 快速 生成 文档 。 

第 四 步 : 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 就 要 往 框架 里 填充 内 容 了 。 在 文档 窗口 中 合适 的 位 置 ， 可 以 输入 
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文字 或 引用 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插 件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面板 或 插 
入 菜单 来 完成 。 

第 五 步 : 发 布 和 维护 更 新 

在 站 点 完成 页 面 的 编辑 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服 务 器 上 的 远 端 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 随时 更 新 和 维护 。 





1.4.2 ”本 地 站 点 网 站 文件 夹 规划 


在 制作 网 站 之 前 首先 要 把 设计 好 的 网 站 内 容 放 置 在 本 地 计算 机 的 硬盘 上 ， 为 了 方便 站 点 的 设 
计 及 上 传 , 设计 好 的 网 页 都 应 存储 在 Apache 服 务 器 的 安装 路 径 下 ,如 本 书 的 路 径 为 D:xampp\htdocs 
目录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 对 本 地 站 点 进行 规划 时 ， 应 该 注意 以 下 操作 规则 。 

1. 设计 合理 的 文件 夹 


在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主 文件 夹 ， 然 后 在 
其 中 创建 多 个 子 文件 夹 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 

例如 ， 可 以 在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 aboutus 文 件 夹 中 放置 用 于 介绍 
公司 的 网 页 ， 可 以 在 service 文 件 夹 中 放置 关于 公司 产品 方面 的 网 页 。 图 1-28 所 示 为 一 个 大 型 电子 商 
务 网 站 规划 建立 的 文档 。 





中 Dsa- as es 
23 反 | 
Er ” Bn 于 








图 1-28 在 本 地 硬盘 上 建立 的 文件 夹 
2. 设计 合理 的 文件 名 称 


网 站 建设 要 生成 的 文件 很 多 ， 所 以 经 常 要 用 合理 的 文件 名 称 。 这 样 操作 的 目的 一 是 为 了 方便 
在 网 站 的 规模 变 得 很 大 时 可 以 进行 修改 和 更 新 , 二 是 为 了 方便 浏览 者 在 看 了 网 页 的 文件 名 后 就 能 够 
知道 网 页 所 要 表述 的 内 容 。 

在 设计 合理 的 文件 名 时 要 注意 以 下 规则 : 

(1) 尽量 为 文件 命名 短 名 称 。 

(2) 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Internet 服 务 器 使 用 的 是 英文 操作 系统 ， 不 能 对 中 文 
文件 名 提供 很 好 的 支持 , 而 且 浏 览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 , 中文 文件 名 同样 可 能 导致 
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浏览 错误 或 访问 失败 。 
(3) 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服 务 器 采用 UNIX 操 作 系 
统 ， 它 是 区 分 文件 大 小 写 的 。 


人 
在 PHP 建 立 站 点 文件 夹 及 文件 名 时 一 定 要 使 用 英文 名 称 或 者 数字 名 称 ， 不 要 使 用 中 文 名 称 
来 命名 ， 否 则 会 导致 Apache 服 务 器 不 能 正常 支持 该 站 点 。 


3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 


在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同上 传 到 Intermet 服 务 器 中 被 人 浏览 的 网 站 文件 结构 
相同 , 这 样 在 本 地 站 点 上 对 相应 的 文件 夹 和 文件 进行 的 操作 , 都 可 以 同 远 程 站 点 上 的 文件 夹 和 文件 
一 一 对 应 。Dreamweaver CC 2017 可 以 将 整个 站 点 上 传 到 Internet 服 务 器 上 ， 保 证 远程 站 点 是 本 地 站 
点 的 完整 备份 ， 方 便 网 站 创建 者 浏览 和 修改 。 


1.4.3 ”建立 流畅 的 浏览 顺序 


在 网 站 创建 时 首先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 否 流畅 。 
如 果 采 用 标准 统一 的 网 页 组 织 形式 , 可 以 让 用 户 轻松 自如 地 访问 每 个 要 访问 的 网 页 , 这 样 能 提高 济 
览 的 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 以 下 儿 个 方面 

(1 ) 每 个 页 面 建立 首页 的 链接 

在 网 站 所 有 的 页 面 上 ， 都 要 放置 返回 主页 的 链接 。 如 果 在 网 页 中 包含 返回 主页 的 链接 ， 就 可 
以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ,快速 返回 到 首页 中 ,重新 开始 浏览 站 点 中 的 其 他 内 容 。 

(2 ) 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 过 导航 提供 站 点 的 简明 目录 结构 ， 引 导 用 户 从 
一 个 页 面 快速 进入 其 他 的 页 面 。 

(3 ) 突出 当前 页 的 位 置 

在 网 站 页 面 很 多 的 情况 下 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 的 主 
题 ， 以 帮助 用 户 了 解 他 们 现在 访问 的 位 置 。 如 果 页 面 嵌 套 过 多 ， 则 可 以 通过 创建 “前 进 ” 和 “后 退 ” 
之 类 的 链接 来 帮助 用 户 进行 浏览 。 

(4) 增加 搜索 和 索引 功能 

对 于 一 些 带 数 据 库 的 网 站 ， 还 应 该 给 用 户 提供 搜索 的 功能 ， 或 是 给 用 户 提供 索引 检索 的 权利 ， 
使 用 户 快速 查找 到 自己 需要 的 信息 。 


(5) 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 用 户 那里 及 时 获取 他 们 对 网 站 的 意见 和 建议 是 非 
常 重要 的 , 为 了 及 时 从 用 户 处 了 解 到 相关 信息 , 应 该 在 网 页 上 提供 用 户 同 网 页 创作 者 或 网 站 管理 员 
的 联系 途径 。 常 用 的 方法 是 建立 留言 板 或 是 创建 一 个 E-mail 超 级 链接 ， 帮 助 用 户 快速 将 信息 回馈 到 
网 站 中 。 
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1.4.4 定义 PHP 网 页 测试 网 站 


使 用 Dreamweaver 要 开发 网 站 之 前 ， 一 定 要 先 定义 网 站 ， 利 用 Dreamweaver CC 2017 的 “站 点 ” 
一 “管理 站 点 ”命令 来 进行 设置 。 使 用 Dreamweaver CC 2017 进 行 网 页 布局 设计 时 ， 首 先 需要 用 定 
义 站 点 向 导 定 义 站 点 。 

定义 第 2 章 开始 学 习 PHP 语 法 网 页 的 站 点 的 具体 操作 步骤 如 下 : 





步 又 014 首先 在 Di\xampp\htdocs 路 径 下 建立 php 文 件 夹 ， 如 图 1-29 所 示 , 第 1 章 学 习 所 有 建立 
的 PHP 程 序 文件 都 将 放 在 该 文件 夹 下 。 





+ mpp » hdocs 





三 OneDrve Ph 


国 = 
图 1-29 建立 站 点 文件 夹 php 


步 邓 02 和 《打开 Dreamweaver CC 2017， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 1-30 所 示 。 
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图 1-30 “管理 站 点 ”对 话 框 


步 野 034 单 击 右 下 角 的 “新 建站 点 ”按钮 ， 打开“ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 
设置 ， 如 图 1-31 所 示 。 


第 1 章 PHP 7.0 开发 环境 的 配置 


“站 点 名 称 ”: php。 
“本 地 站 点 文件 夹 ”: D:\vxampp\htdocs\php。 





站 点 设置 对 象 php x 
pe Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。Dreamweaver 站 

点 通常 包 合 两 个 部 分 ; 可 在 其 中 存储 和 直 理 文件 的 计算 机 上 的 本 地 文件 夫 ， 以 
名 及 可 在 其 中 将 相同 文件 发 布 到 Web 上 的 服务 器 上 的 远程 文件 夫 。 
， 

您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 

站 点 名 称 : php 
本 地 站 中文 件 赤 : Danpptdocspho\ 目 
Cm ) 到) 














图 1-31 建立 php 站 点 


步骤 044 单 击 左 侧 列 表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 呈 ， 选 择 “ 基 
本 ”选项 卡 ， 进 行 如 图 1-32 所 示 的 参数 设置 。 


“服务 器 名 称 ”: php。 

“连接 方法 ”: 本 地 /网 络 。 

“服务 器 文件 夹 ”: D:\xampp\htdocs。 
“Web URL” : http://127.0.0.1/。 





站 高 设置 对 象 php x 
站 5 
有 各 ue EE 
CSS 和 服务 器 名 称 ， php 
站 连接 方法 本 地 有 咯 
服务 加 文件 运 ; D:bampphtdocs 白 


Web URL: [http:/1270.0 本 


电台 服 





CO ) Cj 〇 Cw ) | 入 
图 1-32 “基本 ”选项 卡 设置 

















步 邓 05C 人 设置 后 再 选择 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 “PHP MySQL?” 选项， 表示 是 使 用 PHP 开 
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发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 1-33 所 示 。 











站 点 设置 对 象 php x 
站 点 
有 小 
Css 祯 让 册 | 运程 服务 器 
高 级 设置 回 维护 同步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 启用 文件 取出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 
电子 邮件 地 址 : 
测 式 服务 器 
甩 务 器 模型: [PHPWysQL ~] 
| 
将 文件 自动 推送 到 刺 服 务 器 
口 始终 自动 保存 相关 文件 
Cm ) CH OC WwW) | 入 














图 1-33 设置 “高 级 ”选项 卡 
步骤 064 单 击 “保存 ”按钮 ， 再 进行 “服务 器 ”设置 ， 选 中 “测试 ” 单 选 按钮 ， 如 图 1-34 

















所 示 。 
站 点 设置 对 象 php x 
i 您 在 此 位 置 计 择 承 统 web 上 的 页 面 的 服务 器 .此 对 活 术 的 设置 自 

器 Intemet 慑 务 提供 商 (SP) 或 Web 管理 六 

a Ed En 于 
Ea Dhampplhtdocs WO ©O 
ome 
保存 时 自动 推送 
训 钱 稻 ， 夭 蚁 会 将 文件 自动 推送 到 到 并 服务 器 。 要 禁用 文件 的 自动 推送 ， 请 编辑 服 
和 并 取消 先 中 ` 遍 投 中 的 自动 推 适 堵 现 。 
Cm ) Cm )(C 全) 

















图 1-34 设置 “服务 器 ”参数 

步 又 07 4 单 击 “ 保 存 ” 按 钮 ， 完 成 站 点 的 定义 设置 ， 在 Dreamweaver CC 2017 中 就 会 存在 刚 
才 所 设置 的 站 点 了 。 由 于 我 们 是 在 本 机 测试 PHP 网 页 的 ， 因 此 不 需要 选中 “远程 ” 单 选 按钮 。 设 定 
好 “地 址 ”与 “连接 ”之 后 , 单 击 “ 完 成 ”按钮 , 关闭 “管理 站 点 ”对 话 框 , 这 样 就 完成 了 在 Dreamweaver 
CC 2017 中 测试 PHP 网 页 的 网 站 环境 设置 。 
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1.4.5 制作 第 一 个 PHP 网 页 


使 用 Dreamweaver CC 2017 软 件 可 以 快速 地 创建 PHP 的 标准 文档 , 创建 新 的 PHP 网 页 步骤 如 下 : 


步骤 014 如 果 Dreamweaver CC 2017 已 经 启动 , 要 创建 新 文档 , 可 以 选择 菜单 栏 上 的 “文件 ” 
一 “新 建 ”人 命令， 打开“ 新建 文档 ”对 话 框 ， 如 图 1-35 所 示 。 在 该 对 话 框 的 左 侧 列表 框 中 单 击 “新 
建文 档 ” 选 项 ; 在 “文档 类 型 ”中 选择 一 种 需要 的 类 型 ， 这 里 我 们 选择 “<?>PHP” 类 型 ， 创 建 一 
个 PHP 标 准 文档 ; 然后 在 “布局 ”中 选择 一 种 布局 样式 ， 默 认 情 况 下 选择 “无 ”; 在 “PHP 文 档 ” 
类 型 中 选择 现在 标准 的 “HTML 3” 文档 类 型 ; 最 后 单 击 “ 创 建 ”按钮 即 可 创建 一 个 新 文档 。 


六 x 











Pre Ee- CD 
图 1-35 “新 建文 档 ” 对 话 框 
步骤 02 和 创建 新 的 文档 后 ， 单 击 “ 拆 分 ”按钮 ， 在 代码 文档 窗口 中 输入 PHP 的 显示 命令 如 下 : 


<?php 
echo ("hello,World!， 你 好 世界 ! ! ") 
?> 








设置 如 图 1-36 所 示 。 


DW em Sor) ga SA Im mu) Was) CW wen 
俩 酮 可 > 














图 1-36 在 代码 窗口 输入 PHP 代码 
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步 野 034 保存 网 页 文件 的 方法 随 保存 文件 的 目的 不 同 而 不 同 。 如 果 同 时 打开 了 多 个 
Dreamweaver CC 2017 窗 口 ， 而 保存 的 目的 只 是 为 了 保存 文件 ， 则 切换 到 要 保存 文档 所 在 的 窗口 ， 
然后 选择 菜单 栏 上 的 “文件 ”一 “保存 ”命令 ， 则 会 打开 “另存 为 ”对 话 框 ， 如 图 1-37 所 示 。 如 果 
在 此 以 前 文档 从 未 被 保存 过 ， 则 会 出 现 Windows 标 准 的 文件 存储 对 话 框 。 选 择 路 径 并 输入 文件 名 ， 
单 击 “ 保 存 ” 按 钮 ， 即 可 存储 文档 。 如 果 文 档 已 经 被 保存 ， 则 会 直接 存储 文档 ， 不 会 出 现 Windows 
的 文件 存储 对 话 框 。 


个 «ampp > maccs » php vo sph 四 


pp 一 四 sm 








>Hed: [ET 
PPD: PHP Files (php’.php3r .php php5 .tpl* php-dist*.pheml) v| 
Uricede 远大 - 











~ RE 2 
图 1-37 保存 PHP 网 页 


步骤 044 打开 任意 一 款 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/php/hello.php， 按 回 车 键 ， 
即 可 正常 显示 制作 的 第 一 个 PHP 网 页 ， 如 图 1-38 所 示 。 


360 安 全 浏览 器 8.1 夷 单 | 痢 一 口 ”X 
© € cH 9 Wr 全 v oO. Q 


Db | ©O | Dasg 回 无 本 本 文档 十 妃 > 
hello, World!， 你 好 世界 ! ! 

















图 1-38 浏览 PHP 网 页 


有 很 多 初学 者 第 一 次 访问 网 页 时 并 不 能 成 功 ， 大 部 分 原因 是 因为 没有 启动 前 面 安装 的 XAMPP 
集成 环境 ， 支 持 PHP 运 行 的 Apache 服 务 器 没有 启动 ，PHP 网 页 自然 不 能 顺利 被 访问 。 
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第 章 


PHP 的 基本 语 ; 


PHP 是 一 种 创建 动态 交互 性 站 点 的 强 有 力 的 服务 器 端 脚本 语言 ， 既 然 是 脚本 语言 ， 那 么 在 使 
用 之 前 我 们 就 要 学 习 PHP 的 基本 语法 ， 只 有 掌握 了 基本 语法 才 可 以 方便 地 进行 动态 网 站 的 开发 。 
PHP 7.0 语 法 非常 类 似 于 Perl 和 C， 对 于 有 相关 经 验 的 读者 可 以 非常 轻松 地 掌握 。 本 章 就 介绍 一 些 
PHP 的 基本 语法 ， 包 括 变量 、 常 量 、 运 算 符 、 控 制 语 句 以 及 数组 等 ， 通 过 学 习 这 些 基 础 知识 使 读 
者 能 更 深入 地 了 解 PHP 7.0， 并 能 在 后 面 的 章节 中 轻松 开发 出 动态 网 页 。 

本 章 的 学 习 重 点 
PHP 7.0 基 础 程序 结构 
PHP 7.0 表 单 变 量 的 使 用 
PHP 程 序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 
掌握 MySQL 数 据 库 的 操作 


PHP 7.0 + MySQL 网 站 开发 全 程 实例 


寺村 PHP 基础 程序 结构 


如 果 读 者 对 ASP 或 者 JSP 有 所 了 解 ， 应 该 知道 在 编写 这 些 网 页 程序 时 可 以 将 HTML 标 记 与 这 些 
动态 语言 代码 混合 到 一 个 文件 中 ， 然 后 使 用 特殊 的 标识 (符号 “<%%>”) 将 两 者 区 别 开 来 。PHP 
也 是 如 此 ， 可 以 与 HTML 标 记 共存 ，PHP 提 供 了 多 种 方式 来 与 HTML 标 记 区 别 ， 用 户 可 以 根据 自己 
的 喜好 选择 一 种 ， 也 可 以 同时 使 用 几 种 。 本 节 将 介绍 一 下 PHP 的 基础 程序 结构 ， 包 括 输出 和 注释 的 
方法 。 


2.1.1 基础 程序 结构 


PHP 语 句 与 Perl 以 及 C 一 样 ， 结 构 比 较 严 谨 ， 需 要 在 每 条 语句 后 使 用 分 号 “;” 来 作为 结束 ， 而 
且 对 语句 中 的 大 小 写 敏 感 。 

常用 的 方式 有 如 下 3 种 : 

@ 方法 一 : PHP 标 准 结构 (推荐 ) 

<?php 

Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !"; 

?> 

@ 方法 二 : PHP 的 简短 风格 (需要 设置 php.ini) 

<?Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !"; ?> 

@ 方法 三 : PHP 的 SCRIPT 风 格 (见长 的 结构 ) 

<script language="php">echo"hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !"; </script> 








图 2-1 编辑 的 结果 


实际 开发 时 , 方法 一 和 方法 二 是 比较 常用 的 方法 ， 即 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 码 , 在 
程序 代码 的 最 后 ， 使 用 问号 及 大 于 号 作为 结束 。 方 法 三 有 点 类 似 于 JavaScript 的 编写 方式 。 
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2.1.2 PHP 输出 结果 
PHP 输 出 所 有 参数 可 以 用 echo0 命 令 ，echo() 不 是 一 个 函数 ， 它 是 一 个 语言 结构 ， 因 此 不 一 定 


要 使 用 小 括号 来 指明 参数 ， 单 引号 、 双 引号 都 可 以 。echo() 不 像 其 他 语言 构造 表现 得 像 一 个 函数 ， 
所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo0 传 递 多 个 参数 ， 就 不 能 使 用 小 括号 。 


也 可 以 使 用 print() 命 令 来 实现 ， 但 echo(0) 函 数 比 print() 函 数 快 一 些 。 


举例 使 用 PHP 输 出 语句 ， 包 括 html 格 式 化 标签 ， 如 图 2-2 所 示 。 


休 Dvampp\htdocs\php\php_echophp a 
doctype html 
v <html> 
v <head> 
<meta charset="utf-8"> 
title> 无 标题 文档 </title> 
/head> 
Y <body 
v <?php 
echo "<p> 床 前 明月 光 , 疑 是 地 上 答 。</p>" 
</body> 
/html> 
PHP ~ INsS 13:8 图 


图 2-2 ”使 用 echo 输出 字符 

对 于 初学 者 而 言 一 定 要 掌握 关于 单 引号 和 双 引 号 的 区 别 和 效率 问题 ， 也 有 很 多 开发 者 了 解 得 
不 是 很 清楚 ,一 直 以 为 PHP 中 单 引 号 和 双 引 号 是 互通 的 , 直到 发 现 使 用 单 引号 和 双 引 号 出 现 错误 时 
才 去 学 习 。 所 以 这 里 单独 介绍 它们 的 区 别 , 希望 在 编写 程序 时 建立 好 编辑 规范 。 二 者 的 主要 区 别 如 
下 : 

@ “" 双 引 号 里 面 的 字段 会 经 过 编译 器 解释 ， 然 后 当 作 HTML 代 码 输 出 。 

@ '' 单 引号 里 面 的 字段 不 进行 解释 ， 直 接 输出 。 

从 字面 意思 上 就 可 以 看 出 ， 单 引号 比 双 引 号 程序 运行 要 快 ， 如 下 列 示例 。 


Sabc='my name is tom'7 

echo $abc // 结 果 是 :my name is tom 
echo '$abc' // 结 果 是 :$abc 

echo "$abc”// 结 果 是 :my name is tom 


2.1.3 ”程序 的 注释 
PHP 中 可 以 使 用 多 种 风格 的 注释 方式 ， 如 下 所 示 : 
/* 第 1 种 PHP 注 释 ”适合 用 于 多 行 */ 
// 第 2 种 PHP 注 释 适合 用 于 单行 
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# 第 3 种 PHP 注 释 ”适合 用 于 单行 


注释 和 C、C++、Shell 的 注释 风格 一 样 ， 以 /* 为 开始 、*/ 为 结束 ， 如 下 所 示 : 
<?php 

/* 

注释 关于 本 段 程 序 的 说 明 

该 段 程序 主要 用 于 建立 数据 库 的 连接 …… 

2 


> 


单行 注释 〈 有 /和 # 这 两 种 ) : 
<?php 

echo "说 明 "; // 输 出 说 明 二 字 
echo "说 明 "; # 输 出 说 明 二 字 


> 


注意 一 下 ， 注 释 符 号 只 有 在 <?php ?> 里 面 才 会 起 到 应 有 的 效果 。 


本 本 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 使 用 echo0 函 数 命 令 并 不 能 满足 实际 的 应 用 ， 如 需要 输出 随机 数 
字 、 控制 字符 串 的 大 小 写 以 及 一 些 特殊 的 字符 处 理 等 , 这 些 操作 可 以 通过 调用 相应 的 函数 命令 加 以 


2.2.1 _ PHP 函数 的 调用 


如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 , 在 PHP 编 程 中 调用 相应 的 函数 还 是 比 
较 简 单 的 ， 如 图 2-3 所 示 为 使 用 rand0 函 数 来 产生 一 个 随机 数字 范围 是 0 到 100)〉。 


恒 Dwampp\htdocs\php\php_rand php 芝 百 器 
doctype html 
vw <html 
v <head> 
<meta charset="utf-8"> 
<title> 无 标题 文档 </title> 


/head 


v <body> 
Y <?php 
echo rand(9,199); 
/body> 
/html> 
body PHP ~ INS 311 区 


图 2-3 在 “文档 ”窗口 编辑 随机 函数 


语法 : rand(min,max) 


返回 值 : 输出 在 min 和 max 之 间 可 选 的 任意 值 ， 即 规定 随机 数 产生 的 范围 在 min 和 max 之 间 。 
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<?php 
echo rand(0,100); 
2 


刷新 便 可 看 到 输出 结果 的 变化 ，rand 函 数 中 的 0 和 100 为 指定 给 rand 函 数 的 参数 。 前 面 的 0 意味 
着 最 小 可 能 出 现 的 数值 为 零 , 100 则 意味 着 最 大 可 能 出 现 的 数值 为 100, 很 多 函数 都 有 必 选 或 是 可 选 


的 参数 。 


2.2.2” 截 去 字符 串 首尾 
使 用 trim() 函 数 可 以 返回 字符 串 string 去 除 首尾 的 空白 字符 后 的 字符 串 。 


语法 : string trim(string charlist); 

返回 值 : 字符 串 

函数 种 类 : 资料 处 理 

在 使 用 来 自 HTML 表 单 信 息 之 前 ， 一 般 都 会 对 这 些 数据 做 一 些 整理 。 





<?php 

// 清 理 字 符 串 中 开始 和 结束 位 置 的 多 余 空 格 
Sname = " 12356789 "; 

Sname = trim($name); 

echo $name; 

?> 


运行 的 结果 可 以 将 字符 串 前 后 的 空白 去 除 。 


2.2.3 ”格式 化 输出 字符 


nl2br0) 函 数 可 以 将 换行 字符 转换 成 HTML 换 行 的 <br> 指 令 。 
语法 : string nl2br(string xhtml); 





返回 值 : 字符 串 
函数 种 类 : 资料 处 理 
举例 : 

<?php 


$str = "今天 的 天 气 特别 好 ， 心 情 也 不 错 
， 决 定 去 学 校 足球 场 ， 好 好 地 跑 一 场 球 。"; 
echo $str; 

echo "<br />"; 

echo nl2br($str); 

> 


输出 的 结果 如 图 2-4 所 示 。 
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今天 的 天 气 特别 好 ， 心 情 也 不 错 
， 决 定 去 学 校 足球 场 ， 好 好 地 踢 一 场 球 。 





360 安 全 江 晤 寺 9.1 Ro X 
€C 人 全 人 女 日 127.0.0.1 意 乡 v 全 # 展 ~ 

人 SEE |+ 1 
今天 的 天 气 特别 好 ， 心 情 也 不 错 ， 决 定 去 学 校 足球 场 ， 好 好 地 踊 一 场 球 。 








2-4 格式 化 输出 字符 的 结果 


2.2.4 打印 格式 化 输出 


PHP 支 持 的 print0 结 构 可 以 在 实现 echo 功 能 的 同时 返回 





可 以 实现 更 复杂 的 格式 。 
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语法 : int printfstring format, mixed [args]...); 
返回 值 : 整数 
函数 种 类 :资料 处 理 

举例 : 

<?php 

$num 12.87 

// 将 Snum 里 的 数值 以 字符 串 的 形式 输出 
printf ("数值 为 :$s", Snum) ; 

echo "<br />"; 

// 转 换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf ("数值 为 :%$.2f", $num); 
echo "<br />"; 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf ("数值 为 :$b", $num); 

echo "<br />"; 





值 (True 或 False, 是 否 成 功 ), 使 用 printft) 





// 打 印 $ 符 号 
printf ("数值 为 :%%%s", Snum) ; 
?> 
输出 的 结果 如 图 2-5 所 示 。 
辟 127.0.0.1 
[DE 








于 | 曾 一 口 XX 
$v O- Q 
业 BO 








2-5 打印 格式 化 输出 


将 字符 


2.2.5 ”字母 大 小 写 转换 


第 2 章 PHP 的 基本 语法 


字母 的 大 小 写 转换 在 PHP 网 页 转换 中 经 常 使 用 到 ， 涉 及 的 常用 函数 命令 有 : strtoupper()， 可 以 





举例 : 

<?php 

$str = "I like this game!"; 

// 将 字符 串 转换 成 大 写字 母 

echo strtouPPer ($str) ."<br />"; 
// 将 字符 串 转换 成 小 写字 母 

echo strtolower($str)."<br />"; 


// 将 字符 串 的 第 一 个 字母 转换 成 大 写 


echo ucfirst ($str)."<br />"; 


// 将 每 个 单词 的 第 一 个 字母 转换 成 大 写 
echo ucwords ($str); 
?> 


输出 的 结果 如 图 2-6 所 示 。 





I LIKE THIS GAME! 
i like this game! 
I like this game! 
I Like This Game! 





360 安 全 浏览 启 8.1 
© EAEIE A 127.0.0.1 


Db |O©O | Di 要 园 无 奈 村 文档 


区 间作 | 一 | 口 ] X 
Osiv O. Q 
汪 局 > 








2.2.6 ”处 理 特殊 的 字符 


图 2-6 字母 转换 大 小 写 


将 字符 串 转换 成 大 写字 母 ，ucwords0， 可 以 将 每 个 单词 的 第 一 个 字母 转换 为 大 写 ，ucfirst)， 可 以 
目的 第 一 个 字母 转换 成 大 写 ; strtolower0， 可 以 将 字符 串 转 换 成 小 写字 母 。 


有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杜 和 NULL 字 符 ， 如 何 正 确 处 理 这 些 
字符 ?可 以 使 用 addslashes() 函 数 和 stripslashes() 函 数 。 


<?php 
EE NN MULLIMS 
echo $str."<br />"; 


echo addslashes ($str)."<br />"; 
echo stripslashes ($str)."<br />"; 


运行 的 结果 如 图 2-7 所 示 。 
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360 安 全 浏览 器 8.1 < 束 间 | 曾 一 口 义 
© € CC 全 | 人 日 ht 127.0.0.1 龟 乡 | v 〇 .被 咬 游 客 iQ 
DO | DR 二 回 天 本 文档 x 局 

”N NULL 
\”V \\ NLL 
“ ”NULL 











2-7 ”处 理 特殊 的 字符 


攻 E 时 党 量 和 交 量 

当量 和 变量 是 编程 语言 的 最 基本 构成 要 素 ， 代 表 了 运算 中 所 需要 的 各 种 值 。 通 过 变量 和 常量 ， 
程序 才能 对 各 种 值 进行 访问 和 运算 , 学习 变量 和 常量 是 编程 的 基础 。 常量 和 变量 的 功能 就 是 用 来 存 
储 数 据 的 , 但 区 别 在 于 常量 是 一 旦 初始 化 就 不 再 发 生变 化 , 可 以 理解 为 符号 化 的 常数 。 本 节 将 介绍 
一 下 PHP 中 的 常量 和 变量 。 


2.3.1 PHP 中 的 常量 

常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处 理 不 需要 修改 的 值 时 ， 常 量 非常 有 用 ， 
例如 定义 圆周 率 PI。 常 量 一 旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ， 但 是 可 以 在 程序 的 任何 地 方 
访问 。 

在 PHP 中 使 用 define() 函 数 定义 常量 ， 函 数 第 1 个 参数 表示 常量 名 ， 第 2 个 参数 表示 常量 的 值 。 

语法 : define(name, value, case_insensitive) 

该 函数 有 三 个 参数 : 

@ name: 必 选 参数 ， 常 量 名 称 ， 即 标识 符 。 

@ value: 必 选 参数 ， 常 量 的 值 。 

@ case_insensitive : 可 选 参数 ， 如 果 设 置 为 True， 则 大 小 写 不 敏感 ， 默 认 是 大 小 写 敏 感 。 

常量 在 定义 后 ， 默 认 是 全 局 变量 ， 可 以 在 整个 运行 脚本 的 任何 地 方 使 用 。 

例如 ， 下 面 定 义 一 个 名 为 HOST 的 常量 ， 如 图 2-8 所 示 : 


<?php 


define ("HOST", "www.baidu.com"); // 将 值 “www.baidu.com” 赋 予 常量 HOST 
echo HOST; // 输 出 HOST 常量 的 值 
?> 
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国 ovampp\htdocsphp\php_ varcN php 吉本 区 
1 《ldoctype html> 
2 <html> 
Tchead> 
<meta charset="utf-8"> 
<title> 无 标题 文档 </title> 
</head> 
v <body’| 
v <?php 
19 define("HOST", "www.baidu.com"); 将 启 "“ww. baidu. coms 徊 子 营 蝇 HOS7 
11 echo HOST; ( 葬 册 HOST 党 呈 99 簿 


14 </body> 
1 </html> 


body 回 PHP ~ Ns 87 区 


图 2-8 定义 常量 
A 
常量 默认 区 分 大 小 写 ， 按 照 惯例 ， 常 量 标识 符 总 是 大 写 。 常 量 名 和 其 他 任何 PHP 标 记 遵 循 
相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 画 线 开 始 ， 后 面 跟 任何 字母 、 数 字 或 下 画 线 。 


PHP 的 系统 常量 包括 5 个 魔术 常量 和 大 量 的 预定 义 常量 。 

魔术 常量 会 根据 它们 使 用 的 位 置 而 改变 ，PHP 提 供 的 5 个 魔术 常量 分 别 是 : 

(1) _LINE_: 表示 文件 中 的 当前 行 号 。 

(2) _FILE_: 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 自 
PHP 4.0.2 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 路 径 。 

(3) _FUNCTION_: 表示 函数 名 称 (PHP 4.3.0 新 加 ) 。 自 PHP 5 起 ， 该 常量 返回 函数 被 定义 
时 的 名 字 《 区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 。 

(4) _CLASS_: 表示 类 的 名 称 (PHP 4.3.0 新 加 〉 。 自 PHP 5 起 ， 该 常量 返回 类 被 定义 时 的 名 
字 ( 区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 。 

(5) _METHOD_: 表示 类 的 方法 名 (PHP 5.0.0 新 加 ) ， 返 回 方法 被 定义 时 的 名 字 〔 区 分 大 小 
写 

预定 义 常量 分 为 内 核 预 定义 常量 和 标准 预定 义 常量 两 种 , 内 核 预 定义 常量 在 PHP 的 内 核 、Zend 
引擎 和 SAPI 模 块 中 定义 , 而 标准 预定 义 常量 是 PHP 默 认定 义 的 , 比如 常用 的 E_ERROR、E_NOTICE、 
E_ALL 等 。 





| 





2.3.2 PHP 中 的 变量 


变量 是 指 在 程序 的 运行 过 程 中 随时 可 以 发 生变 化 的 量 ， 在 代码 中 可 以 只 使 用 一 个 变量 ， 也 可 
以 使 用 多 个 变量 , 变量 中 可 以 存放 单词 、 数 值 、 日 期 以 及 属性 等 。 变量 的 值 是 临时 的 ， 当 程序 运行 
时 ， 该 值 是 存在 的 ， 如 果 程 序 结束 ， 变 量 的 值 就 会 清空 。 虽然 在 前 面 的 示例 中 也 使 用 到 了 变量 , 但 
是 没有 详细 的 说 明 ， 本 小 节 将 详细 介绍 如 何 创建 变量 ， 以 及 如 何 引 用 变量 。 在 PHP 中 ,创建 一 个 变 
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量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 号 开头 ， 然 后 是 变量 名 。 如 果 在 声明 
变量 时 ， 忘 记 变 量 前 面 的 $ 符 号， 那么 该 变量 将 无 效 。 在 PHP 中 设置 变量 的 正确 方法 如 下 : 

$var name = value; 

1. 定义 变量 

在 PHP 中 , 给 变量 赋值 有 两 种 方式 ,分别 为 值 赋 值 和 引用 赋值 。 值 赋值 是 直接 把 一 个 数值 通过 
赋值 表达 式 赋值 给 变量 ， 会 把 该 变量 原来 的 数值 覆盖 。 如 果 在 声明 变量 时 ， 没 有 赋值 ， 其 行为 就 形 
同 NULL。 在 声明 变量 时 ， 赋 值 是 一 种 常用 的 变量 的 赋值 方法 ， 示 例如 下 : 


<?php 

$name = "baidu"; // 有 效 变 量 

SName = "website"; // 有 效 变 量 

echo "$name, SName"7 // 输 出 为 “baidu，website” 
$lwebsite = "www.baidu.com"; // 无 效 变量 ， 以 数字 开始 
$_lwebsite = "www.baidu.com"; // 有 效 变 量 

Epd 


从 上 述 代码 中 可 以 看 到 , 在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ,而 是 根据 变量 被 
设置 的 方式 ，PHP 会 自动 把 变量 转换 为 正确 的 数据 类 型 。 

在 PHP 中 ， 标 识 符 的 命名 必须 符合 下 面 的 规定 : 

(1) 标识 符 可 以 由 一 个 或 多 个 字符 组 成 ， 但 必须 以 字母 或 下 画 线 开 头 。 此 外 ， 标 识 符 只 能 由 
字母 、 数 字 、 下 夯 线 、 字 符 和 从 127 到 255 的 其 他 ASCII 字 符 组 成 。 如 my_a、Ss、_value 这 些 标识 符 
名 称 都 是 合法 的 ， 而 q^a、4tt 这 些 标识 符 的 名 称 是 不 合法 的 。 

(2) 标识 符 区 分 大 小 写 。 因 此 ，S$recipe 不 同 于 $Recipe、S$rEciPe 或 $recipE。 

(3) 标识 符 可 以 是 任意 长 度 。 这 很 有 好 处 ， 因 为 这 样 一 来 ， 程 序 员 就 能 通过 标识 符 名 称 准确 
地 描述 标识 符 的 用 途 。 

(4) 标识 符 名 称 不 能 与 任何 PHP 预 定义 关键 字 相同 。 

在 PHP 中 ， 变 量 的 命名 规则 有 如 下 几 点 : 

@ 变量 名 必须 以 字母 或 下 画 线 " "开头 。 

@ 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 画 线 。 

@ 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 画 线 进行 分 

隔 (例如 Smy _string ) ， 或 者 以 大 写字 母 开 头 (例如 $myString ) 。 


在 PHP 中 ， 还 支持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 如 下 面 的 示例 : 


<?php 

Swo = 'baidu'; // 为 变量 $wo 赋 值 

Sba = &$wo; // 取 变量 $ba 引 用 了 变量 $wo 的 值 

Sba = "Web site is $ba"; // 修 改变 量 $ba 的 值 

echo S$wo; // 结 果 为 “Web site is baidu” 
echo $ba; // 变 量 $ba 的 值 也 被 修改 ， 结 果 与 $wo 相 同 
?> 


从 这 里 可 以 看 出 ， 对 一 个 变量 值 的 修改 将 会 导致 对 另外 一 个 变量 值 的 改变 。 从 本 质 上 讲 ， 变 
量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 , 不 论 对 哪 一 个 变量 进行 修改 , 修改 的 是 同 
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一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同时 被 修改 的 结果 。 

PHP 提 供 了 大 量 的 预定 义 变量 , 这 些 变量 在 任何 范围 内 自动 生效 , 因此 通常 也 被 称 为 自动 全 局 
变量 (autoglobals ) 或 者 超 全 局 变量 (superglobals) ， 而 且 PHP 中 没有 用 户 自 定义 超 全 局 变量 的 机 
制 。 在 PHP 4.1.0 之 前 ， 使 用 超 全 局 变量 时 ， 人 们 要 么 依赖 register_globals， 要 么 使 用 宛 长 的 预定 义 
PHP 数 组 ($SHTTP * VARS ) 。 自 PHP 5.0.0 起 ， 长 格式 的 PHP 预 定义 变量 可 以 通过 设置 
register_ long_arrays 来 屏蔽 。 

常用 的 超 全 局 变量 如 下 : 


@ $GLOBALS: 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 ， 该 数组 
的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 SGLOBALS 数 组 。 

@ $_ SERVER: 变量 由 Web 服 务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 ， 类 似 
于 旧 数 组 SHTTP_SERVER_VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_GET: 经 由 URL 请 求 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_GET_ VARS ( 依 
然 有 效 ， 但 反对 使 用 ) 。 

@ $_ POST: 经 由 HTTP POST 方法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ 
POST _VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_ COOKIE: 经 由 HTTP Cookies 方 法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ 
COOKIE_VARS (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_FILES: 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ 
POST _FILES (依然 有 效 ， 但 反对 使 用 ) 。 

@ $_ENV: 执行 环境 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ENV_VARS (依然 有 
效 ， 但 反对 使 用 ) 。 

@ $ REQUEST: 经 由 GET、POST 和 COOKIE 机 制 提 交 至 脚本 的 变量 ， 因 此 该 数组 并 
不 值得 信任 .所 有 包含 在 该 数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按照 php.ini 
中 的 variables_order 配 置 指示 来 定义 。 此 数组 在 PHP 4.1.0 之 前 没有 直接 对 应 的 版 
本 。 

@@ $_SESSION: 当前 注册 给 脚本 会 话 的 变量 , 类 似 于 旧 数 组 SHTTP_SESSION_VARS 
(依然 有 效 ， 但 反对 使 用 ) 。 


2. 变量 作用 域 

声明 变量 的 位 置 决定 了 变量 的 作用 域 ， 变 量 的 作用 域 决定 了 程序 的 哪些 部 分 可 以 访问 该 变量 、 
哪些 部 分 不 可 以 访问 该 变量 。 在 PHP 中 ， 变 量 的 作用 域 范围 可 以 分 为 4 类 : 局 部 变量 、 函 数 参数 、 
全 局 变量 和 静态 变量 。 这 里 介绍 一 下 变量 的 这 几 种 作用 域 范围 。 


(1) 局 部 变量 

在 一 个 函数 中 声明 一 个 变量 是 某 个 函数 的 局 部 变量 ， 也 就 是 说 该 变量 只 能 被 该 函数 内 部 成 员 
访问 ， 函 数 外 部 成 员 不 能 访问 该 变量 ， 并 且 不 可 见 。 默 认 情况 下 ， 函 数 内 部 成 员 不 能 访问 在 函数 外 
定义 的 变量 (平常 所 说 的 全 局 变量 ) 。 有 时 局 部 变量 很 有 用 ， 因 为 局 部 变量 能 够 消除 出 现 移 位 副 作 
用 的 可 能 性 , 否则 这 些 副 作用 将 导致 可 全 局 访问 的 变量 被 有 意 或 无 意 地 修改 。 下面 创建 一 个 使 用 局 
部 变量 的 示例 。 
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<?php 

$count =10; 

function AddCount () 

{ 
$count 100; 
$count $count + $count; 
echo $count; 
echo "<br/>"; 


} 

AddCount (); 

echo $count; 
?>7 


执行 结果 如 下 所 示 : 
200 
10 
从 输出 结果 可 知 , 该 段 代码 输出 了 两 个 不 同 的 值 , 这 是 因为 AddCount() 函 数 中 的 变量 为 局 部 变 
量 , 修改 局 部 变量 的 值 不 会 影响 函数 外 部 的 任何 值 ， 函 数 中 的 变量 在 程序 结束 时 被 抛弃 ， 所 以 全 局 
变量 值 还 是 10。 
(2) 函数 参数 
在 PHP 中 ,函数 可 以 接受 相应 的 参数 , 虽然 这 些 参 数 是 接受 函数 外 部 的 值 , 但 退出 函数 后 就 无 
法 访问 这 些 参数 ,在 函数 执行 结束 后 ,参数 的 值 就 会 消失 ， 和 函数 的 执行 有 很 大 的 关系 。 函 数 参数 
是 在 函数 后 面 的 括号 内 声明 ， 运 用 函数 参数 的 示例 如 下 : 
<?php 
function EchoNum($age, $class) 
{ 
echo "年 龄 是 : " .$age."<br/>"; 
echo "班级 是 : " .$class; 
} 
EchoNum(21, "计算 机 技术 与 科学 系 17 级 2 班 ") ; 


党 过 
执行 该 段 代码 ， 执 行 结果 如 下 所 示 : 
年 龄 是 ;21 


班级 是 : 计算 机 技术 与 科学 系 17 级 2 班 
函数 参数 也 可 以 称 为 局 部 变量 ， 意 味 着 这 些 参数 只 在 函数 内 部 起 作用 ， 在 函数 的 外 部 不 能 访 
问 这 些 变量 ， 同 样 当 函 数 执行 结束 时 ， 变 量 也 会 撤销 。 
(3 ) 全 局 变量 
全 局 变量 可 以 在 整个 PHP 程 序 中 的 任何 地 方 访问 , 但 是 如 果 要 修改 一 个 全 局 变量 , 就 必须 在 修 
改 该 变量 的 函数 中 显 式 地 声明 为 全 局 变量 , 在 函数 中 显 式 声明 全 局 变量 很 简单 , 只 需 在 函数 中 使 用 
global 关 键 字 声明 就 可 以 ， 下 面 创建 一 个 使 用 全 局 变量 的 示例 : 


<?php 
function RddNum() 
{ 
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执行 结果 如 下 所 示 : 


如 果 不 在 $num 前 加 global， 该 变量 会 被 认为 是 局 部 变量 , 此 时 页 面 上 显示 的 值 为 0; 添加 global 
后 , 就 可 以 修改 全 局 变量 了 。 声明 全 局 变量 还 有 另外 一 种 方法 , 那 就 是 使 用 PHP 的 SGLOBALS 数 组 ， 
使 用 该 数组 和 使 用 global 关 键 字 的 效果 一 样 ， 下 面 创建 一 个 使 用 GLOBALS 数 组 的 示例 ; 





执行 结果 如 下 所 示 : 
| 
在 使 用 全 局 变量 时 ， 一 定 要 注意 ， 因 为 使 用 全 局 变量 很 容易 发 生意 外 。 


(4) 静态 变量 
静态 变量 在 两 次 调用 函数 之 间 其 值 不 变 ， 仅 在 局 部 函数 域 中 声明 。 用 关键 字 static 可 以 声明 一 
个 静态 变量 。 静 态 变量 在 函数 退出 时 ， 不 会 丢失 值 ， 并 且 再 次 调用 此 函数 时 ， 还 能 保留 值 。 创 建 一 
个 使 用 静态 变量 的 示例 : 





执行 结果 如 下 所 示 : 
变量 num 的 值 是 :10 
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静态 变量 的 值 是 : 1 
静态 变量 的 值 是 ，2 


由 于 在 函数 中 指明 了 变量 为 静态 变量 ， 因 此 在 执行 函数 时 保留 了 前 面 的 值 。 





2.3.3 “PHP 数据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 处 理 的 


员工 工 
中 ， 为 
型 ， 分 


资 额 ， 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 ， 所 有 这 些 都 是 数据 。 在 编程 语言 
了 方便 对 数据 的 处 理 以 及 节省 有 限 的 内 容 资 源 ， 需 要 对 数据 进行 分 类 。PHP 支 持 7 种 原始 类 
别 是 : 

boolean: 布尔 型 True/False。 

integer: 整数 类 型 。 

float: 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 。 

string: 字符 串 类 型 。 

array: 数组 ， 用 来 保存 同类 型 的 多 条 数据 。 

object: 对 象 。 

特殊 类 型 : resource 资 源 和 NULL 未 设 定 。 


下 面 介绍 这 几 种 常用 的 数据 类 型 。 


布 


布尔 型 (boolean) 
尔 型 是 最 简单 的 数据 类 型 ， 有 两 个 值 ， 即 True 和 False。 要 指定 一 个 布尔 值 ， 使 用 关键 字 True 


或 False， 并 且 True 或 False 不 区 分 大 小 写 。 例 如 : 
$pay = true; // 给 变量 $Spay 赋 值 为 true 


某 





些 运算 通常 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 (一 ) 来 比较 两 个 操 








作 数 ， 如 果 相 等 ， 则 返回 True， 和 否则 返回 False， 代 码 如 下 : 


了 


($A == $B) { 


echo "$A 与 $B 相等 "; 


} 
对 


了 





于 如 下 的 代码 : 
(Spay == TRUE) { 


echo "已 付 "; 


} 


可 
EE 


以 使 用 下 面 的 代码 代替 : 
($pay) { 


echo mE 


} 


转换 成 布尔 型 可 以 用 bool 或 者 boolean 来 强制 转换 ， 但 是 很 多 情况 下 不 需要 用 强制 转换 ， 因 为 
当 运 算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 该 值 会 被 自动 转换 。 
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当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False: 
布尔 值 False。 

整 型 值 0 ( 零 ) 。 

浮 点 型 值 0.0 ( 零 ) 。 

空白 字符 串 和 字符 串 “0”。 

没有 成 员 变 量 的 数组 。 

没有 单元 的 对 象 ( 仅 适用 于 PHP 4) 。 
特殊 类 型 NULL (包括 尚未 设 定 的 变量 ) 。 


所 有 其 他 值 都 被 认为 是 True (包括 任何 资源 ) 。 
2. 整 型 (integer) 


一 个 整数 是 集合 Z = {…, -2, -1, 0, 1, 2, …} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 进 制 或 八 
进 制 表示 ， 前 面 可 以 加 上 可 选 的 符号 〈- 或 者 +) 。 如 果 用 八进制 ， 数 字 前 必须 加 上 0( 零 ) ; 用 十 
六 进 制 ， 数 字 前 必须 加 上 0x。 整 型 数 的 字 长 和 平台 有 关 ， 通 常 最 大 值 大 约 是 20 亿 〈32 位 有 符号 ) 。 
PHP 不 支持 无 符号 整数 。 如 果 给 定 的 一 个 数 超出 了 整 型 的 范围 ， 将 会 被 解释 为 浮 点 型 ， 同 样 如 果 执 
行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强 制 转换 。 不 过 大 多 数 情况 下 都 不 需要 强制 转换 ， 因 为 
当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 值 会 自动 转换 。 还 可 以 通过 函数 intval(0 来 将 一 个 
值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 会 转换 为 0，True 将 会 转换 为 1。 当 从 浮 点 数 转换 成 整数 时 ， 数 字 
将 被 取 整 〈 丢 弃 小 数位 ) 。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 的 精度 使 浮 
点 数 给 出 一 个 确切 的 整数 结果 。 


3. 浮 点 型 (float) 
浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 


<?php 
$a = 1.234; 
$b = 1.2e3; 
$c = 7E-10; 
?> 


浮 点 数 的 字 长 和 平台 相关 ， 通 常 最 大 值 是 1.8e+308， 并 具有 14 位 十 进 制 数字 的 精度 。 
4. 字符 串 (string) 


字符 串 是 由 引号 括 起 来 的 一 些 字符 ， 常 用 来 表示 文件 名 、 显 示 消息 、 输 入 提示 符 等 。 字 符 串 
是 一 系列 字符 ， 字 符 串 的 长 度 没有 限制 。 字 符 串 可 以 用 单 引 号 、 双 引号 或 定 界 符 3 种 方法 定义 ， 下 
面 分 别 介绍 这 3 种 方法 。 





(1) 单 引号 
指定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引 号 〈") 括 起 来 。 例 如 : 
<?php 
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echo 'Hello World '; // 输出 为 : Hello World 

2 

如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引号 ， 和 其 他 很 多 语言 一 样 ， 需 要 用 反 斜 线 (\) 
转 义 。 例 如 : 

<?php 

echo 'I\'m Tom'; // 输出 为 : I’m Tom 

x 

如 果 在 单 引号 之 前 或 字符 串 结尾 需要 出 现 一 个 反 斜 线 (\) ， 和 需要 用 两 个 反 人 针线 QV) 表示。 例如: 

<?php 

echo 'Path is c:\windows\system\\'; // 输出 为 : Path is c:\windows\system\ 

2> 

对 于 单 引 号 (') 括 起 字符 串 ，PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 果 试 图 转 义 任何 其 
他 字符 ， 反 和 斜 线 本 身 也 会 被 显示 出 来 。 另 外 ， 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 一 点 就 是 ， 单 
引号 字符 串 中 出 现 的 变量 不 会 被 解析 。 

(2) 双 引 号 

如 果 用 双 引 号 〈") 括 起 字符 串 ，PHP 懂 得 更 多 特殊 字符 的 转 义 序列 〈 见 表 2-1) 。 











表 2-1 ” 转 义 字符 

序列 含义 

un 换行 

Yr 回 车 

vt 水 平 制 表 符 

\ 反 和 斜 杠 字符 

KR 美元 符号 

by 双 引 号 

Onnn 此 正则 表达 式 序列 匹配 一 个 用 八进制 表示 的 字符 
Wnn 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 表示 的 字符 





如 果 试 图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 双 引号 字符 串 最 重要 的 一 点 是 能 
够 解析 其 中 的 变量 。 


(3) 定 界 符 
另 一 种 给 字符 串 定 界 的 方法 是 使 用 定 界 符 语法 (<<<) 。 应 该 在 <<< 之 后 提供 一 个 标识 符 ， 接 
着 是 字符 串 ， 然 后 是 同样 的 标识 符 结束 字符 串 。 例 如 : 
<?php 
// 输出 为 : Hello World 
echo <<<abc 
Hello World 


abc; 
> 
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在 此 段 代 码 中 ， 标 识 符 命名 为 abc。 结 束 标 识 符 必须 从 行 的 第 一 列 开始 。 标 识 符 所 遵循 的 命名 
规则 是 : 只 能 包含 字母 、 数 字 、 下 画 线 ， 而 且 必 须 以 下 画 线 或 非 数字 字符 开始 。 

定 界 符 文本 表现 的 就 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 着 在 定 界 符 文本 中 不 需 
要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 被 解析 。 在 以 上 3 种 定义 字符 串 的 方 
法 中 ， 若 使 用 双 引 号 或 者 定 界 符 定义 字符 串 ， 其 中 的 变量 会 被 解析 。 


5. 数组 (array) 


PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映 射 到 key 的 类 型 。 新 建 一 个 数组 使 用 
array() 语 法 结构 ， 它 接受 一 定数 量 用 逗号 分 隔 的 key => value 参 数 对 。 
语法 如 下 : 


array( [ key => ] value , ... ) 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数组 ， 则 可 以 
形成 多 维 数组 的 数据 结构 。 例 如 : 

<?php 

$edName = array(0 =>"id", 1=>"username", 2=>"password"); 

echo " 列 名 是 $edName [0]，S$edName[1],，S$edName [2]"; 

?> 

此 段 代码 的 输出 为 : 列 名 是 id、usermame、password。 

如 果 省 略 了 键 key， 会 自动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 

<?php 

$edName = array("id", "username", "password"); 

echo " 列 名 是 SedName [0]，S$edName[1]，S$edName [2]"; 

> 

此 段 代 码 的 输出 仍 为 : 列 名 是 id、username、password。 

如 果 key 是 整数 , 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 果 指 定 的 键 已 经 有 了 值 ， 
则 新 值 会 覆盖 旧 值 。 再 次 改写 上 面 的 代码 为 : 

<?php 

$edName = array (l=>"id", "username", "password"); 

echo " 列 名 是 SedName [1]，S$edName[2],， SedName[3]"; 

二 

此 段 代 码 的 输出 仍 为 : 列 名 是 id、username、password。 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实现 ， 也 
可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 空 的 方 括号 ([]) 。 

语法 如 下 : 

$arrayName [key] = value; 

$arrayName [] = value; 

其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 


<?php 
$edName [0]= "id"; 
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$edName [1]= "username"; 

$edName [2]= "password"; 

echo " 列 名 是 SedName [0]，S$edName[1], S$edName[2]"; 

?> 

此 段 代 码 的 输出 仍 为 : 列 名 是 id、usemame、password。 

如 果 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 果 当 前 还 
没有 整数 索引 ， 则 键 将 为 0。 如 果 指 定 的 键 已 经 有 值 了 ， 该 值 将 被 覆盖 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 字 符 串 和 资源 等 ， 如 果 将 一 个 值 转换 为 数组 ， 将 得 
到 一 个 仅 有 一 个 元 素 的 数组 〈 其 下 标 为 0) ， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转换 成 一 个 
数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 〈 成 员 变 量 ) ， 其 键 为 成 员 变量 名 。 如 果 将 一 个 NULL 
值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 


6. 对 象 〈object) 


使 用 class 定 义 一 个 类 ， 然 后 使 用 new 类 名 《构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数据 类 型 将 
在 后 面 的 实例 具体 应 用 中 进行 解析 。 


7. 其 他 数据 类 型 


除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 ， 下 面 简单 介绍 一 下 资源 和 
NULL 两 种 特殊 数据 类 型 。 


(1) 资源 

资源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 引用 。 可 以 保存 
打开 文件 、 数 据 库 连 接 、 图 形 画布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 转换 为 资源 。 资 源 大 部 
分 可 以 被 系统 自动 回收 。 


(2) NULL 

NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 特 殊 的 NULL 值 表示 一 个 变量 没 
有 值 。 

例如 : 


<?php 

Dn 

if(isset ($a)) 

echo "[1] is NULL<br>"; 
$php = 0; 

if(isset ($a)) 

echo "[2] is NULL<br>"; 
$php = NU11; 

if(isset ($a)) 

echo "[3] is NULL<br>"; 
$php = FALSE; 

if(isset ($a)) 

echo "[4] is NULL<br>"; 
2 








结果 是 什么 ? 
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在 以 下 三 种 情况 下 变量 被 认为 是 空 值 : 

@ 变量 没有 被 赋值 ; 

@ 变量 被 赋值 为 NULL、0、False 或 者 空 字符 囊 ; 
@ 变量 在 非 空 值 的 情况 下 ， 被 unset 函 数 释 放 。 


2.3.4 ”数据 类 型 转换 
在 PHP 中 若 要 进行 数据 类 型 的 转换 ， 就 要 在 转换 的 变量 之 前 加 上 用 括号 括 起 来 的 目标 类 型 。 在 
变量 定义 中 不 需要 显 式 的 类 型 定义 ， 变 量 类 型 是 由 使 用 该 变量 的 上 下 文 所 决定 的 。 
例如 通过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 另外 一 种 类 型 ; 


<?php 
$num = 123; // 当 前 是 整数 类 型 
$float = (float) $num; //$num" 临 时 性 "地 转换 成 了 浮 点 型 , $f1oat 变 量 所 携带 的 


数据 类 型 就 为 浮 点 型 
echo gettype (Snum) ."<br />"; // 使 用 gettype (mixed var) 函数 来 获取 变量 类 型 
echo gettype ($float) 









?> 
在 文档 窗口 中 的 编辑 如 图 2-9 所 示 。 
加 oampp\ntdocs\php\php_gettype.php I 
v <head 
<meta charset="utf-8"> 
<title> 无 标题 文档 </title> 
</head> 
v <body> 
10v <?php 
1 和 
gettype(Snum)."<br />"; 
gettype($float) 
</body> 
</html> 
body PHP ~ INS 15:4 区 
图 2-9 数据 类 型 的 转换 
运行 的 结果 是 : 
Integer 
Double 


要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 得 使 用 settype(mixed var,string type) 函 数 。 
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允许 的 强制 转换 有 : 


int、integer: 转换 成 整 型 。 
bool、boolean: 转换 成 布尔 型 。 
float、double、real: 转换 成 浮 点 型 。 
string: 转换 成 字符 串 。 

array: 转换 成 数组 。 

object: 转换 成 对 象 。 


二 要 PHP 中 的 运算 符 


对 于 学 过 其 他 语言 的 读者 ， 运 算 符 应 该 不 会 陌生 ， 运 算 符 可 以 用 来 处 理 数 字 、 字 符 串 及 其 他 
的 比较 运算 和 逻辑 运算 等 。 在 PHP 中 ,运算 符 两 侧 的 操作 数 会 自动 地 进行 类 型 转换 ， 这 在 其 他 的 编 
程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 三 种 类 型 的 运算 符 ， 它 们 分 别 是 : 

@ 一 元 运算 符 : 只 运算 一 个 值 ， 例 如 ! ( 取 反 运算 符 ) 或 ++ ( 加 一 运算 符 ) 。 
二 元 运算 符 : PHP 支 持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 $a + $b。 
三 元 运算 符 : 即 ?， 它 用 来 判断 一 个 表达 式 是 否 成 立 ， 然 后 在 另外 两 个 表达 式 中 选 
择 一 个 ， 而 不 是 用 来 在 两 个 语句 或 者 程序 路 线 中 选择 。 


PHP 中 常用 的 运算 符 有 算术 运算 符 、 赋值 运算 符 、 比 较 运算 符 、 三 元 运算 符 、 错误 控制 运算 符 、 
逻辑 运算 符 、 字 符 串 运算 符 、 数 组 运算 符 等 。 本 节 主 要 介绍 常用 的 运算 符 ， 以 及 运算 符 的 优先 级 。 


2.4.1 算术 运算 符 


算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 也 是 最 常用 的 符号 ， 尤 其 是 对 数字 的 处 理 ， 
几乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 所 示 。 


























表 2-2 算术 运算 符 

符号 意义 
< $a 的 负 值 
十 $a 和 $b 的 和 
E $a 和 $b 的 差 
* $a 和 Sb 的 积 
/ $a 除 以 Sb 的 商 
% $a 除 以 Sb 的 余数 
++ | Sa++ 累加 $a 的 累加 

Ee 递减 Sa 的 递减 
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人 
DB, 

除 号 (/) 总 是 返回 浮 点 数 ， 即 使 两 个 操作 数 是 整数 (或 由 字符 串 转 换 成 的 整数 ) 也 是 这 
样 。 


2.4.2 ”赋值 运算 符 


赋值 运算 符 〈Assignment Operator) 把 表达 式 右边 的 值 赋 给 左边 的 变量 或 常量 。 基 本 的 赋值 运 
算 符 是 =， 意 味 着 把 右边 表达 式 的 值 赋 给 左边 的 操作 数 。PHP 中 的 赋值 运算 符 如 表 2-3 所 示 。 


表 2-3 ”赋值 运算 符 





I$a= $a+$b 
I$a= $a- $b 

I$Sa= Sa* $b 

即 $a= $a/S$b 

将 左边 的 值 对 右边 的 值 取 余数 赋值 给 左边 ， 即 $a = $a % $b 


四 | 到 | 于 














除 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运 算 符 的 “组 和 运算 符 ”， 这 样 
可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结果 赋 给 它 ， 例 如 : 

<?php 

$a ="baidu"; 

$b =".com"; 

echo $a .= $b; 

?> 

运行 结果 : 


baidu.com 


2.4.3 ”比较 运算 符 


比较 运算 符 (Comparison Operator) ， 顾名思义 就 是 可 用 来 比较 的 操作 符号 ， 根 据 结果 来 返 
True 或 False。 比 较 运算 符 ， 人 允许 对 两 个 值 进 行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 


表 2-4 ”比较 运算 符 





= 




















例子 名 称 意义 
$a—=— $b 等 于 Tme， 如 果 $a 等 于 Sb 
$a— $b 全 等 Tme， 如 果 $a 等 于 Sb， 并 且 它 们 的 类 型 也 相同 
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( 续 表 ) 
例子 名 称 意义 
$al=$b 不 恒 等 Tme， 如 果 $a 不 恒 等 于 $b 
$a 一 $b 不 等 Tme， 如 果 $a 不 等 于 Sb 
$a (== $b 非 全 等 Trme， 如 果 $a 不 等 于 $b， 或 者 它们 的 类 型 不 同 PHP 4 引进 ) 
$a < $b 小 于 Tme， 如 果 $a 严格 小 于 Sb 
$a> $b 大 于 Trme， 如 果 $a 严格 大 于 $b 





$a <= $b 小 于 等 于 Tme， 如 果 $a 小 于 或 者 等 于 $b 
$a >= $b 大 于 等 于 Trme， 如 果 $a 大 于 或 者 等 于 $b 

















2.4.4 三 元 运算 符 


三 元 运算 符 是 ?:， 三 元 运算 符 的 功能 和 if..else 语 句 很 相似 ， 语 法 如 下 : 
(expr1l) ? (expr2) : (expr3) 
首先 对 exprl 求 值 ， 若 结果 为 True， 则 表达 式 (exprl) ? (expr2) : (expr3) 的 值 为 expr2， 否 则 其 值 
为 expr3。 例 如 : 
<?php 
$action = (empty($_POST['action'])) ? 'default' : $ POST['action']; 
?> 
首先 判断 $_POST['action] 变量 是 否 为 空 值 ， 若 是 则 将 $action 赋 值 为 default， 否 则 将 
$_POST['action"] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 代码 : 


<?php 
if (empty($ POST['action'])) { 
$action = 'default'; 
} else { 
$action = $_POST['action']; 
} 
?> 


2.4.5 ”错误 抑制 运算 符 


抑制 运算 符 (@) 可 在 任何 表达 式 前 使 用 ，PHP 支 持 一 个 错误 抑制 运算 符 @。 当 将 其 放置 在 一 个 
PHP 表 达 式 之 前 ， 该 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 掉 。@ 运 算 符 只 对 表达 式 有 效 。 

那么 ， 何 时 使 用 此 运算 符 呢 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 就 能 在 它 前 面 加 
上 @ 运 算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 和 include() 中 调用 ， 放 在 常量 等 之 前 。 不 能 把 它 放 在 
函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 ， 如 if 和 foreach 等 。 

对 于 以 下 的 代码 : 

<?php 

$Conn= mysqli connect ("localhost","username", "pwd"); 
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if ( $Conn) 
echo "连接 成 功 ! "7 


else 
echo "连接 失败 ! "; 
如 果 mysqli_connect0 连 接 失败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程序 。 如 果 不 
想 显示 系统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代码 ， 如 下 所 示 : 
<?php 


$Conn = @mysqli connect ("localhost","username", "pwd") or die ("连接 数据 库 服 务 
器 出 错 "); 
2 





在 mysql_connect() 函 数 前 加 上 @ 运 算 符 来 屏蔽 系统 的 错误 提示 ， 同 时 使 用 die() 函 数 给 出 自 定义 
的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 


2.4.6 ”逻辑 运算 符 


PHP 的 逻辑 运算 符 (Logical Operators) 通常 用 来 测试 真 假 值 , 常用 的 逻辑 运算 符 如 表 2-5 所 示 。 
表 2-5 ” 示 辑 运算 符 











“与 ”和 “或 ”有 两 种 不 同形 式 的 运算 符 ， 它 们 运算 的 优先 级 不 同 ，&& 和 || 优 先 级 高 。 


2.4.7 ”字符 串 运算 符 


字符 串 运算 符 〈String Operator) 有 两 个 字符 串 运 算 符 。 第 一 个 是 连接 运算 符 〈.) ， 它 返回 其 
左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 符 〈.=) ， 它 将 右边 参数 附加 到 左边 的 参数 后 。 
例如 : 














<?php 

$a = "你 好 "; 

$a = $a . "朋友 !"; // 此 时 $a 是 "你 好 朋友 !" 
$b = "你 好 "; 


$b .= "朋友 !"; // 此 时 Sb 是 "你 好 朋友 !" 


‘y 
Ww 
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2.4.8 数组 运算 符 
PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 
表 2-6 ”数组 运算 符 








意义 
$a 和 $b 的 联合 ， 返 回 包含 了 $a 和 $b 中 所 有 元 素 的 数组 
如 果 $a 和 $b 具有 相同 的 元 素 就 返回 True 
两 者 具有 相同 元 素 且 顺序 相同 返回 True 
如 果 $a 和 $b 不 是 等 价 的 就 返回 Tme 
如 果 $a 不 等 于 $b 则 返回 True 
如 果 $a 和 $b 不 是 恒 等 的 就 返回 Tme 
联合 运算 符 (+) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 是 重复 的 键 值 不 会 被 覆盖 。 下 面 通 
过 一 个 实例 来 看 一 下 如 何 用 联合 运算 符 〈+) 联合 两 个 数组 : 






































$a = array ("1"=>"Nol1", 
"2"=>"No2", 
"3"=>"No3", 
"4"=>"No4") 7 


$b = array ("3"=>"No3", 
"an=>"Nod", 

"HNm"NOS™, 

"6"=>"No6") 7 

$c = $Sa+Sb7 
Print_r($c); // 联 合 两 数组 


echo "<br />"7 


if ($a==$b) 
echo "等 价 "; 
else 


echo "不 等 价 "; 
> 


可 以 看 到 ， 在 联合 之 后 的 数组 结果 如 图 2-10 所 示 。 





~、 3002 SET YX |] 
© CO 全 日 127.0.0.1 vO. Q 
b © 0 回 天 5 村 >x 档 十 局 
Array ( [1] => Nol [2] =》 No2 [3] => No3 [4] => No4 [5] => No5 [6] => No6 ) 
不 等 价 





2-10 ”联合 数组 示例 
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2.4.9 运算 符 的 优先 级 


运算 符 优先 级 指定 了 两 个 表达 式 绑 定 得 有 多 “紧密 ”。 例 如 ， 表 达 式 1 + 2 * 3 的 结果 是 7 而 不 
是 9， 是 因为 乘 号 〈* ) 的 优先 级 比 加 号 (+) 高 。 必 要 时 可 以 用 括号 来 强制 改变 优先 级 ， 例 如 (1 +2)* 3 
的 值 为 9， 使 用 括号 也 可 以 增加 代码 的 可 读 性 。 如 果 运 算 符 优先 级 相同 ， 则 使 用 从 左 到 右 的 左 结合 


顺序 〈 左 结合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 相反 ) 。 
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表 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具 有 相同 优先 级 ， 此 时 它 




















们 的 结合 方向 决定 求 值 顺 序 。 
表 2-7 ”运算 符 优先 级 
结合 方向 运算 符 附加 信息 
非 结合 new new 
左 [ array() 
非 结合 ++-- 递增 / 递减 运算 符 
非 结合 ! ~- (inb (float) (string) (array) (objecb @ 类 型 
左 */% 算数 运算 符 
左 +- 算数 运算 符 和 字符 串 运算 符 
左 <<> 位 运算 符 
非 结合 <<=> 盖 比较 运算 符 
非 结合 一 二 -一 ! 一 比较 运算 符 
左 & 位 运算 符 和 引用 
左 了 位 运算 符 
左 | 位 运算 符 
左 && 逻辑 运算 符 
左 | 逻辑 运算 符 
左 和 和 三 元 运算 符 
右 = 二 一 二 三 -=%=&== 人 <<=>>= 赋值 运算 符 
左 and 逻辑 运算 符 
左 xor 逻辑 运算 符 
左 or 逻辑 运算 符 
左 多 处 用 到 











将 结合 前 面 所 用 到 的 运算 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 : 


<?php 

// 定 义 几 个 常量 ， 最 好 是 使 用 大 写 
define ("PEN"，20); // 钢 笔 为 20 元 
define ("RULE",10); // 尺 子 为 10 元 
$pen num = 10; //10 只 钢笔 
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er_num =20; //20 把 尺子 


al price = $pen num * PEN 


+ $ruler num * RULE; 


Stot 


echo 
?> 


al price = number format($total price); 


"购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ".$total_price. "元 "; 


输出 的 结果 如 图 2-11 所 示 。 


127.0.01 Fv>O 





ms 和 GB 
购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 400 元 





图 2-11 运算 符 的 综合 应 用 


李 汪 表单 交 量 的 使 用 


在 H 


TML 中 ,表单 拥有 一 个 特殊 功能 : 它们 支持 交互 作用 。 除 了 表单 之 外 ， 几 乎 所 有 的 HTML 


元 素 都 与 设计 以 及 展示 有 关 ， 只 要 愿意 就 可 将 内 容 传送 给 用 户 ; 另 一 方面 ,表单 为 用 户 提供 了 将 信 
息 传 送 回 Web 站 点 创建 者 和 管理 者 的 可 能 性 。 如 果 没 有 表单 ，Web 就 是 一 个 静态 的 网 页 图 片 。 对 于 


PHP 的 动 


态 网 页 开发 ， 使 用 表单 变量 对 象 也 是 经 常 遇 到 的 ， 通 常 主要 有 post() 和 get0 两 种 方法 ， 这 


和 其 他 动态 语言 开发 的 命令 是 一 样 的 ， 本 节 就 介绍 表单 变量 的 使 用 方法 。 


2.5.1 


POST 表单 变量 


用 于 设置 处 理 表单 数据 的 类 型 , POST 是 系统 的 默认 值 ， 表示 将 数据 表单 的 数据 提交 到 “动作 ” 
属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 HTML 表 单 用 method="post" 的 方式 传递 给 本 页 一 个 
name="test" 的 文字 信息 ， 可 用 三 种 风格 来 显示 这 个 表单 变量 : 

<?php 





Echo S$test; // 简 短 格式 ， 需 配置 php .ini 中 的 默认 设置 
echo $_POST["test"]; // 中 等 格式 ， 推 荐 使 用 这 种 方式 

echo $HTTP_POST_VARS["test"];  // 宛 长 格式 

?> 

在 body 之 间 输 入 : 


<form method="post" action=""> 
<input type="text" size="20" name="test"/> 
<input type="submit" value=" 提 交 变 量 "/> 
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</form> 
<?php 
echo $ POST['test']; 
2> 
在 文档 窗口 中 编辑 ， 如 图 2-12 所 示 。 
条 pwampp\ntdocs\php\php_formvarpost php” 六 
htmty 
v <head> 

<meta charset="utf-8"> 

<title> 无 标题 文档 </title> 

echo $_POST['test']; 

/body 

2 pp 627x77 ms 26 网 
图 2-12 POST 表单 测试 

GET 和 POST 的 主要 区 别 是 : 


@ 数据 传递 的 方式 以 及 大 小 ; 
@ GET 会 将 传递 的 数据 显示 在 URL 地 址 上 ，POST 则 不 会 ; 
@ GET 传 递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


2.5.2” GET 表单 变量 


GET 表 示 追 加 表单 的 值 到 URL 并 且 发 送 服务 器 请 求 ， 对 于 数据 量 比较 大 的 长 表单 最 好 不 要 用 
这 种 数据 处 理 方式 。 

假设 有 一 HTML 表 单 用 method="get" 的 方式 传递 给 本 页 一 个 name="test" 的 文字 信息 ， 可 用 三 种 
风格 来 显示 这 个 表单 变量 : 

<?php 

Echo S$test; // 简 短 格式 ， 需 要 配置 php .ini 中 的 默认 设置 

echo $ GET["test"]; // 中 等 格式 ， 推 荐 使 用 此 方法 


echo $HTTP GET VARS["test"]; // 宛 长 格式 
?> 


制作 form.html 网 页 并 输入 如 下 的 代码 : 


<html> 

<head> 

<meta charset="utf-8"> 
<title> 表 单传 递 </title> 
</head> 
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<body> 

<form action="welcome.php" method="get"> 
用 户 : <input type="text" name="name"> 
年 龄 : <input type="text" name="age"> 
<input type="submit" value=" 登 录 "> 
</form> 

</body> 

</html> 


再 制作 一 个 welcome.php 代 码 页 面 ， 输 入 的 代码 如 下 : 


<!doctype html> 

<html> 

<head> 

<meta charset="utf-8"> 
<title> 无 标题 文档 </title> 

</head> 

<body> 

欢迎 <?php echo $_GET["name"]; ?> 登录 ! <br> 
年 龄 是 <?php echo $_GET["age"]; ?> 岁 。 
</body> 

</html> 


输出 的 结果 如 图 2-13 所 示 。 





360 安 全 浏览 器 8.1 槛 单 | 曾 一口 XxX 
© € C 从 会 Hhttp//127.0.0.1/php/welcome.php ET 2 ~ 


加 和 要 和 ->) 














图 2-13 GET 表单 测试 
如 图 2-13 所 示 的 结果 , 在 浏览 器 地 址 栏 里 显示 了 表单 变量 传递 的 值 ， 所 以 在 发 送 密码 或 其 他 敏 
感 信息 时 ， 不 应 该 使 用 这 个 方法 。 但 是 ， 正 因为 变量 显示 在 URL 中 ， 因 此 可 以 在 收藏 夹 中 收藏 该 页 
面 。 在 某 些 情况 下 ,这 是 很 有 用 的 。HTTP GET 方 法 不 适合 大 型 的 变量 值 ， 它 的 值 不 能 超过 2000 个 
字符 。 


2.5.3 ”字符 串 的 连接 


在 PHP 程 序 里 要 让 多 个 字符 串 进行 连接 ， 要 用 到 一 个 (.) “点 ”号 ， 如 下 列 代码 所 示 : 


<?php 
S$website = "baidu"; 
echo $website.".com"; 
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上 面 的 输出 结果 就 是 baidu.com。 

有 一 种 情况 ， 当 echo 后 面 使 用 的 是 双 引 号 〈") 时 可 以 达到 和 上 述 代码 同样 的 效果 : 
<?php 

Swebsite = "baidu"; 


echo "$website.com";// 双 引号 里 的 变量 可 以 正常 显示 出 来 ， 并 和 一 般 的 字符 串 自 动 区 分 开 来 


?> 


如 果 是 单 引号 ， 就 会 将 里 面 的 内 容 完 全 以 字符 串 形式 输出 给 浏览 器 : 
<?php 

S$website = "baidu.com"; 

echo 'S$website.com'; 

2> 


将 显示 $website.com。 


2.5.4 表单 的 验证 


在 PHP 表 单 提 交 时 需要 对 用 户 输入 进行 验证 , 验证 的 方法 是 通过 客户 端 脚本 直接 进行 验证 后 再 
提交 到 服务 器 ， 这 样 操作 会 让 浏览 器 验证 速度 更 快 ， 并 且 可 以 减轻 服务 器 的 负载 。 如 果 用 户 输入 需 
要 插入 数据 库 , 应 该 考虑 使 用 服务 器 验证 。 在 服务 器 验证 表单 的 一 种 好 的 方式 就 是 把 表单 传 给 它 自 
己 ， 而 不 是 跳 转 到 不 同 的 页 面 。 这 样 用 户 就 可 以 在 同一 张 表 单 页 面 得 到 错误 信息 ,用 户 也 就 更 容易 
发 现 错误 了 。 

下 面 列举 一 个 简单 的 表单 验证 实现 方法 的 示例 : 

<!DOCTYPE HTML> 

<html> 

<head> 

<meta charset="utf-8"> 

<title> 表 单 验证 </title> 

<style> 

.error {color: #FF0000;} 

</style> 

</head> 
<body> 
<?php 

// 定义 变量 并 默认 设置 为 空 值 

SnameErr = $emailErr = $genderErr = S$websiteErr = ""; 

Sname = $email = $gender = $comment = S$website = ""; 

3 ($_SERVER["REQUEST METHOD"] == "POST") 

{ 

if (empty($_POST["name"])) 

上 
$nameErr = "名 字 是 必需 的 "; 

} 

else 

{ 
Sname = test input($ POST["name"]); 
// 检测 名 字 是 否 只 包含 字母 跟 空 格 


if (!preg match("/^[a-zA-Z2 ]*$/",$name)) 
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$data = trim($data); 

$data = stripslashes ($data); 
$data = htmlspecialchars ($data); 
return $data; 


一 


Se 


<h2> 表 单 验 证 : </h2> 
<p><span class="error">* 星 号 红色 表示 必需 字段 。</span></p> 
<form method="post" action="<?php echo htmlspecialchars($_ SERVER 
["PHP SEDLE™"])??>"> 
姓名 : 
<input type="text" name="name" value="<?php echo $name;?>"> 
<span class="error">* <?php echo $nameErr;?></span> 
<br><br> 
邮箱 : 
<input type="text" name="email" value="<?php echo $email;?>"> 
<span class="error">* <?php echo $emailErr;?></span> 
<br><br> 
网 址 : 
<input type="text" name="website" value="<?php echo S$website;?>"> 
<span class="error"><?php echo S$websiteErr;?></span> 
<br><br> 
说 明 : 
<textarea name="comment" rows="5" cols="40"><?php echo $comment;?> 
</textarea> 
<br><br> 
性 别 : 
<input type="radio" name="gender" <?php if (isset($gender) && S$gender== 
"male") echo "checked";?> value="male"> 男 
<input type="radio" name="gender" <?php if (isset($gender) && S$gender== 
"female") echo "checked";?> value="female"> 女 
<span class="error">* <?php echo S$genderErr;?></span> 
<br><br> 
<input type="submit" name="submit" value=" 提 交 验 证 "> 
</form> 
<?php 
echo "<h2> 输 入 内 容 如 下 :</h2>"; 
echo $name; 
echo "<br>"; 
echo $email; 
echo "<br>"; 
echo S$website; 
echo "<br>"; 
echo $comment; 
echo "<br>"; 
echo S$gender; 
?> 
</body> 
</html>> 


运行 后 直接 提交 ， 会 在 相关 的 字段 显示 * 号 后 面 的 提醒 功能 ， 如 图 2-14 所 示 。 
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E I TX 
Oe 127001 加 


Ei 
sv 
Dp 10 las [53 + 忆 D 








性 别 ; 日 男 日 立 ， 性 齐 生 乡 震 的 
| 据 束 输 证 


输入 内 容 如 下 : 








图 2-14 GET 表单 测试 


这 里 对 用 户 所 有 提交 的 数据 都 通过 PHP 的 htmlspecialchars(0) 函 数 进 行 处 理 验 证 。 当 用 户 提交 表 
单 时 ， 可 能 输入 的 字符 前 面 有 空格 或 者 换行 ， 需 要 将 提交 的 字符 做 以 下 处 理 : 

(1) 使 用 PHP trim() 函数 去 除 用 户 输入 数据 中 不 必要 的 字符 ， 如 空格 、tab 和 换行 等 。 

(2) 使 用 PHP stripslashes() 函 数 去 除 用 户 输入 数据 中 的 反 斜 杠 〈\) 。 

在 执行 以 上 脚本 时 ,会 通过 $_SERVER["REQUEST_METHOD"] 来 检测 表单 是 否 被 提交 。 如 果 
REQUEST_METHOD 是 POST， 表 单 将 被 提交 ， 数 据 将 被 验证 。 如 果 表 单 未 提交 将 跳 过 验证 并 显示 
空白 。 


本 时 PHP 表 达 式 


在 PHP 程 序 中 ,任何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 作 表达 式 。 也 就 是 说 ,表达 式 是 一 个 短 
语 ， 能 够 执行 一 个 动作 ， 并 具有 返回 值 。 一 个 表达 式 通 常 由 两 部 分 构成 ， 一 部 分 是 操作 数 ， 另 一 部 
分 是 运算 符 。 本 节 介 绍 常用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语句 、 循 环 语句 ， 以 及 require 和 
include 语 句 等 。 





2.6.1 条 件 语句 


条 件 语句 在 PHP 中 非常 普遍 ， 是 PHP 程 序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 端 获得 一 
个 参数 ， 根 据 传 入 的 参数 值 做 出 不 同 的 响应 。 在 PHP 中 条 件 语 句 分 别 为 if 语 句 、if-else 语 句 、 
if-elseif-else 语 句 和 switch 语 句 。 

下 面 我 们 分 别 介绍 这 4 种 形式 的 条 件 语 句 。 


1. if 语句 

if 语 句 是 许多 高 级 语言 中 重要 的 控制 语句 ， 使 用 if 语 句 可 以 按照 条 件 判 断 来 执行 语句 ， 增 强 了 
程序 的 可 控制 性 。 只 有 if 语 句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 

if ( expr ) 

statement 
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首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如果 值 为 False， 将 忽略 statement。 
图 2-15 所 示 为 上 述 语法 格式 在 执行 时 的 流程 图 。 


Start 








False 〈 假 ) 


图 2-15 站 语句 控制 流程 图 


例如 : 
<?php 
$Num1=10; 
SNum2=97 
ifE (SNum1l>SNum2) 
echo "SNum1 大 于 SNum2"7 
?> 


上 述 实 例 展示 了 if 语 句 的 使 用 ， 会 在 变量 SNum1 大 于 $SNum2 时 输出 “$Numl 大 于 $SNum2”。 
2. if-else 语句 


条 件 语句 的 第 二 种 形式 是 if...else， 除 了 if 语 句 之 外 ， 还 加 上 了 else 语 句 ， 它 可 以 在 if 语 句 中 表达 
式 的 值 为 False 时 执行 ， 语 法 如 下 : 

1 expr 

statementl1 


else 
statement2 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement1; 如 果 值 为 False， 则 执行 statement2。 
if-else 语 句 的 流程 图 如 图 2-16 所 示 。 
True ( 真 ) 


Start 





False( 假 ) 
2-16 if-else 语句 控制 流程 图 
以 下 代码 中 在 $a 大 于 $b 时 显示 “a 大 于 b”， 反 之 则 显示 “a 不 大 于 b”: 


<?php 

if ($a > $b) 
echo "a 大 于 b"; 

else 





59 


PHP 7.0 + MySQL 网 站 开发 全 程 实例 


echo "a 不 大 于 b"7 


2> 


人 


else 语 句 仅 在 if 以 及 elseif ( 如 果 存 在 ) 语句 中 的 表达 式 的 值 为 False 时 执行 ， 不 可 以 单独 使 
出 


3. if-elseif-else 语句 


条 件 语句 的 第 三 种 形式 是 if...elseif...else，elseif 是 if 和 和 else 的 组 合 。 和 else 语 句 一 样 ， 它 延伸 了 让 
语句 ， 可 以 在 原来 {表达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 语 句 不 同 的 是 ， 它 仅 在 elseif 的 条 
件 表 达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 

if ( expl ) 

Statement1 

elseif ( exp2 ) 

statement2 

elseif ( exp3 ) 

else 

statementn 


首先 对 expr1 求 值 ， 如 果 expr1 的 值 为 True， 则 执行 statement1; 如 果 值 为 False， 则 对 expr2 求 值 ; 
如 果 expr2 的 值 为 True， 则 执行 statement2; 如 果 值 为 False， 则 对 expr3 求 值 ， 以 此 类 推 ， 如 果 所 有 的 
表达 式 的 值 都 为 False， 则 执行 statementn 。 

这 种 情况 的 执行 流程 图 如 图 2-17 所 示 。 


True ( 真 ) 程序 片段 1 





图 2-17 if-elseif-else 语句 控制 流程 图 


例如 以 下 代码 将 根据 条 件 分 别 显 示 “a 大 于 b”“a 等 于 b” 和 “a 小 于 b”: 


<?php 

if ($a > $b) { 
echo "a 大 于 b"; 

} elseif ($a == $b) { 
echo "a 等 于 b"; 
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} else { 
echo "a 小 于 bb"; 
> 


人 
) 
elseif 也 可 以 写成 else if ( 两 个 单词 ) ， 它 和 elseif ( 一 个 单词 ) 的 行为 完全 一 样 。 


4. switch 语句 


使 用 switch 语 句 可 以 避免 大 量 地 使 用 if-else 控 制 语 句 。switch 语 句 首先 根据 变量 值得 到 一 个 表达 
式 的 值 ， 然 后 根据 表达 式 的 值 执 行 语句 。switch 语 句 计 算 expression 的 值 ， 然 后 和 case 后 的 值 进 行 比 
较 ， 跳 转 到 第 一 个 匹配 的 case 语 句 开 始 执 行 后 面 的 语句 ， 如 果 没 有 case 匹 配 就 跳 转 到 default 语 句 执 
行 ， 如 果 没 有 default 语 句 ， 则 退出 。 到 找到 匹配 项 的 时 候 ， 解 析 器 会 一 直 运 行 直 到 switch 结 尾 或 者 
遇见 break 语 句 。case 语 句 可 以 使 用 空 语句 。 
PHP 提 供 了 分 支 (switch) 语句 来 直接 处 理 多 分 支 选择 ， 语 法 如 下 : 
Switch (expr) { 
case constant-expression: 
statement 
jump-statement 
[default: 
statement 
jump-statement 
] 
} 
其 中 的 常量 表达 式 (constant-expression) 可 以 是 任何 求 值 为 简单 类 型 的 表达 式 ， 即 整 型 或 浮 
点 数 以 及 字符 串 。 
其 流程 图 如 图 2-18 所 示 。 








2-18 switch 语句 控制 流程 图 
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下 面 一 段 代 码 是 switch 语 句 的 简单 应 用 : 
<?php 
switch ($a) { 
case 0O: 
echo "a = 0"; 
break; 
case 1: 
echo "a = 1"; 
break; 
case 2: 
echo "a = 2"7 
break; 
} 


> 
Switch 语句 一 行 接 一 行 地 执行 (实际 上 是 语句 接 语 句 ), 开始 时 没有 代码 被 执行 , 仅 当 一 个 case 
语句 中 的 值 和 switch 表 达 式 的 值 匹配 时 PHP 才 开始 执行 语句 ， 直 到 switch 的 程序 段 结 束 或 者 遇 到 第 
一 个 break 语 句 为 止 。 如 果 不 在 case 语 句 段 最 后 写 上 break，PHP 将 继续 执行 下 一 个 case 中 的 语句 段 。 
例如 : 
<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
case 1: 
echo "a = 1"; 
case 2: 
echo "a = 2"; 
1 
?> 
这 里 如 果 $a 等 于 0, PHP 将 执行 所 有 的 输出 语句 ; 如 果 $a 等 于 1, PHP 将 执行 后 面 两 条 输出 语句 ; 
只 有 当 $a 等 于 2 时 才 会 得 到 结果 : a = 2。 


2.6.2 ”循环 语句 
循环 语句 也 称 为 迭代 语句 ， 让 程序 重复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表 达 式 结果 为 
假 时 ， 结 束 执行 程序 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循 环 、do-while 循 环 、for 循 环 和 foreach 
1. while 循环 语句 
while 语 句 控制 语句 的 循环 执行 。 格 式 是 : 


while (expr) 
statement 


只 要 expr 的 值 为 True 就 重复 执行 嵌 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 值 ， 有 时 如 果 
while 表 达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 说 ， 在 代码 片段 中 会 改变 
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表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循环 。 图 2-19 所 示 为 该 语句 的 控制 流程 图 。 





图 2-19 ”while 语句 控制 流程 图 


例如 : 

<?php 

$a = 1 

while ($a <= 5) { 


echo $a++; // 从 1 到 5 依次 输出 
?> 


执行 该 程序 后 会 输出 从 1 到 5 的 数字 。 

2. do-while 循环 语句 

do-while 语 句 和 while 语 句 基 本 一 样 ， 不 同 之 处 在 于 while 语 句 在 “{}” 内 的 语句 执行 之 前 检查 
条 件 是 否 满足 ， 而 do-while 语 句 则 先 执行 “f}” 内 的 语句 ， 然 后 判断 条 件 是 耕 满足 ， 如 果 满 足 就 继 
续 循环 ， 不 满足 就 跳出 循环 : 

do 


statement 
while (expr) 


图 2-20 所 示 为 该 语句 的 流程 图 。 


Trme ( 真 ) 





图 2-20 ”do-while 语句 控制 流程 图 
例如 : 


<?php 

Sa = 0; 

do 1 

echo $a; 

} 
while ($a > 0); 
?> 
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以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检查 表达 式 的 值 是 否 为 真 时 ， 其 值 为 
False ($a 不 大 于 0) 而 导致 循环 终止 。 


3. for 循环 语句 
for 循 环 是 PHP 中 最 复杂 的 循环 结构 。for 循 环 的 语法 是 : 


for (exprl; expr2; expr3) 
statement 
其 中 ， 第 1 个 exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr2 在 每 次 循环 开始 前 求 值 。 如 果 值 
为 True， 则 继续 循环 ， 执 行 嵌 套 的 循环 语句 。 如 果 值 为 False， 则 终止 循环 。 第 3 个 expr3 在 每 次 循环 
之 后 被 求 值 (执行 》。 每 个 表达 式 都 可 以 为 空 ，expr2 为 空 意 味 着 将 无 限 循环 下 去 (和 C 一 样 ，PHP 
认为 其 值 为 True) 。 因 为 有 时 候 会 希望 用 break 语 句 来 结束 循环 而 不 是 用 for 的 表达 式 真 值 判断 。 
图 2-21 所 示 为 该 语句 的 流程 图 ， 表 达 式 2 为 True 则 执行 程序 片段 ， 其 值 在 表达 式 1 中 初始 化 ,在 


表达 式 3 中 进行 修改 。 
+ 


False ( 假 ) 









> 


图 2-21 for 语句 控制 流程 图 
下 面 通过 使 用 for 循 环 语句 输出 九 九 乘法 表 : 
<?php 
for ($i=1; $i<10;$i++) 
{ 
for ($j=1;$j<10;$j++) 
{ 
echo "$i#*$j=".$i*$j? 
echo "gnbsp"; 
上 
echo "<br/>"; 
} 
> 


4. foreach 循环 语句 

foreach 语 句 是 一 种 遍历 数组 的 简便 方法 。foreach 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 
型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。 有 两 种 语法 格式 ,第 二 种 格式 不 重要 但 却 是 第 一 种 格式 
的 有 用 扩展 。 

@ 第 一 种 格式 : 


foreach (array expression as $value) 
statement 
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@ 第 二 种 格式 
foreach (array expression as $key => $value) 
statement 
第 一 种 格式 遍历 给 定 的 array_expression 数 组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 $value 并 且 数 
组 内 部 的 指针 向 前 移 一 步 (因此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 ) 。 第 二 种 格式 可 以 执行 相同 的 
功能 , 只 是 除了 当前 单元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key。 其 执行 的 流程 图 如 图 2-22 所 示 。 


False 假 ) 





图 2-22 foreach 语句 逻辑 示意 图 


该 语句 的 使 用 方法 如 下 : 
<?php 
$arr = array ("one", "two", "three"); 
foreach ($arr as $value) { 
echo "Value: $value<br />\n"; 
} 


?> 
此 段 代 码 的 输出 为 : 


Value: one 
Value: two 
Value: three 


在 这 段 代码 中 遍历 数组 使 用 的 是 foreach 语 句 的 第 一 种 格式 ， 也 可 以 使 用 第 二 种 格式 ， 改 写 上 
面 的 代码 如 下 : 

<?Pphp 

$arr = array ("one", "two", "three"); 

foreach ($arr as $key => $value) { 

echo "Key: $key; Value: $value<br />\n"; 

}?> 

此 段 代码 的 输出 为 : 

Key: 0; Value: one 


Key: 1; Value: two 
Key: 2; Value: three 


2.6.3 ”其 他 语句 


为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 , 方便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 语句 ， 这 
里 做 一 下 简单 的 介绍 。 
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1. break 语句 


break 语 句 用 来 结束 当前 的 for、while 或 switch 循 环 结 构 ， 继 续 执行 下 面 的 语句 。break 语 句 后 面 
可 以 跟 一 个 数字 ， 用 于 在 嵌 套 的 控制 结构 中 表示 跳出 控制 结构 的 层 数 。 


2. continue 语句 


continue 语 句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 面 的 语句 ， 而 是 回 到 循环 判断 表达 式 ， 并 
决定 是 否 继续 执行 循环 体 。continue 语 句 后 面 同样 可 以 跟 一 个 数字 ， 作 用 和 break 语 句 相 同 。 


3. return 语句 


retum 语 句 通常 用 于 函数 中 , 如果 在 一 个 函数 中 调用 return 语 句 , 将 立即 结束 此 函数 的 执行 并 将 
它 的 参数 作为 函数 的 值 返回 。 


4. include() 语 句 和 require() 语 句 


包含 并 运行 指定 文件 ,require() 和 include0) 除 了 处 理 失 败 之 外 , 在 其 他 方面 都 完全 一 样 。include() 
产生 一 个 警告 ， 而 require0) 则 导致 一 个 致命 错误 。 也 就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 
应 该 使 用 require()， 而 include() 则 会 继续 执行 脚本 ， 同 时 也 要 确认 设置 了 合适 的 include_path。 


5. require_once() 语 句 和 include_once() 语 句 








require_once() 语 名 和 include_once() 语 句 分 别 对 应 require() 语 句 和 include() 语 句 。require_once() 
语句 和 include_once() 语 句 主要 用 于 需要 包含 多 个 文件 时 ,可 以 有 效 地 避免 把 同一 段 代码 包含 进去 而 
出 现 函数 或 变量 重复 定义 的 错误 。 


攻关 phptz 娄 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 代码 写 在 一 起 ， 但 这 样 容易 引起 混乱 。 另 一 种 策略 就 
是 把 总 的 功能 分 成 小 的 功能 模块 , 把 每 一 个 模块 分 别 实现 , 在 总 的 框架 中 根据 需要 把 模块 搭建 在 一 
起 。 实 现 程 序 模块 化 的 策略 就 是 使 用 函数 ， 直 观 来 说 ， 函 数 就 是 代表 一 组 语句 的 标识 符 ， 在 使 用 函 
数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 函数 的 输入 和 输出 接口 的 应 用 。 函 
数 可 以 简单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 另 一 类 是 用 户 自 定义 函数 。 对 于 系统 函数 ， 可 以 在 需 
要 时 直接 选择 使 用 ; 而 用 户 自 定义 函数 ， 首 先 要 定义 ， 然 后 才能 使 用 。 本 节 的 重点 是 如 何 定义 并 使 
用 用 户 自 定义 函数 ， 主 要 包括 函数 定义 的 一 般 形式 、 函 数 的 参数 和 返回 值 、 函 数 的 棋 套 和 递归 等 。 


2.7.1 使 用 函数 
一 个 函数 可 用 以 下 语法 来 定义 : 


function funcName([$arg 1][, $arg 2][, ...][, $arg n]){ 
statement 
1 


定义 函数 时 需要 使 用 function 关 键 字 ， 之 后 是 函数 名 ， 有 效 的 函数 名 必须 以 字母 或 下 夯 线 作为 
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起 始 ， 后 面 跟 字母 、 数 字 或 下 画 线 。$arg_1 到 $arg_n 为 函数 的 可 选 参 数列 表 ， 不 同 的 参数 之 间 用 去 
号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代 码 ， 甚 至 包括 其 他 函数 和 类 定义 。 
例如 : 


<?php 

function maxNum($a, $b){ 
$c=$a>$b?$a: $b; 

return $c; 

} 

echo maxNum(10,100); // 输出 : 100 
?> 


上 面 的 一 段 代码 也 可 以 写成 : 

<?php 

echo maxNum(10,100); // 输出 : 100 
function maxNum($a, $b) { 
$c=$a>$b?$a: $b; 

return S$c; 

1 


2.7.2 ”设置 函数 参数 


通过 函数 参数 列表 可 以 传递 信息 到 函数 .PHP 支 持 按 值 传递 参数 , 通过 引用 传递 以 及 默认 参数 。 
默认 情况 下 , 函数 参数 通过 值 传递 , 即 若 在 函数 内 部 改变 了 参数 的 值 , 也 不 会 影响 到 函数 外 部 的 值 。 

例如 : 

<?php 

function change ($string){ 

$string = "改变 之 后 "7 

} 

$str = "改变 之 前 "; 

change ($str); 

echo $str; 

?> 


这 段 代 码 的 输出 为 “改变 之 前 ”。 尽 管 在 函数 内 部 定义 了 参数 $string 的 值 ， 并 没有 影响 到 函数 
外 部 $str 的 值 。 如 果 希 望 允许 函数 可 以 修改 它 的 参数 值 ， 必 须 通过 引用 传递 参数 ， 方 法 是 在 函数 定 
义 的 参数 前 面 预先 加 上 && 符 号。 

修改 上 面 的 代码 如 下 : 


<?php 

function change(&g$string){ 
$string = "& 改 变 之 后 "; 

上 

$str = "改变 之 前 "7 

change ($str); 

echo $str; 

2 
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这 段 代码 的 输出 为 “改变 之 后 ”。 在 函数 内 部 改变 了 参数 $string 的 值 , 也 影响 到 了 函数 外 部 $str 
的 值 。 前 后 两 段 代码 的 唯一 区 别 就 是 , 后 面 一 段 代码 的 参数 传递 是 引用 传递 , 即 在 函数 定义 的 参数 


前 面 加 上 了 & 符 号 。 


2.7.3 返回 函数 值 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 。 主 要 是 通过 使 用 可 选 的 return0) 语 名 返回 





任何 类 型 都 可 以 返回 , 其 中 包括 列表 和 对 象 。 这 导致 函数 立即 结束 它 的 运行 , 并且 将 控制 权 传 递 


它 被 调用 的 行 。 
举例 如 下 : 


<?php 
$numl=100; 
$num2=200; 
echo "最 大 的 是 " .maxNum ($numl，S$num2); // 输出 : 最 大 的 是 200 
function maxNum($a, $b){ 
if($a<$b) $a = $b; 
return $a; 
} 
?> 


2.7.4 ”函数 艇 套 和 递归 


值 。 





忆 











PHP 中 的 函数 可 以 嵌 套 地 定义 和 调用 。 所 谓 嵌 套 定 义 ， 就 是 在 定义 一 个 函数 时 ， 其 函数 体内 又 
包含 另 一 个 函数 的 完整 定义 。 这 个 内 嵌 的 函数 只 能 在 包含 它 的 函数 被 调用 之 后 才 会 生效 ,举例 如 下 : 


<?php 
function foo() 
{ 

function bar() 

{ 

echo "并 没有 关闭 直到 foo () 函数 被 应 用 。"; 
} 
} 
/* 不 能 棋 套 应 用 bar () 函数 ， 因 为 它 并 没有 被 关闭 。 */ 
foo(); 
/* 现 在 可 以 应 用 bar () 函数 ， 

foo () 's 的 进程 允许 使 用 。 */ 
bar(); 
?> 


这 段 代 码 的 输出 为 “并 没有 关闭 直到 foo() 函 数 被 应 用 。” 

所 谓 嵌 套 调用 ， 就 是 在 调用 一 个 函数 的 过 程 中 又 调用 另 一 个 函数 。 举 例如 下 : 
<?php 

$numl=100; 


$num2=200; 
myoutput ($numl, $num2); 
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function myoutput ($a, $b){ 
echo "最 大 的 是 " .maxNum ($a, $b); 
} 
function maxNum($a, $b){ 
if($a<$b) $a = $b; 
return $a; 
1 
?> 
这 段 代 码 的 输出 是 “最 大 的 是 200”。 在 此 段 代 码 中 首先 调用 的 是 myoutput0) 函 数 ， 而 在 调用 
这 个 函数 的 过 程 中 又 调用 了 另 一 个 函数 maxNum()， 这 就 是 函数 的 嵌 套 调用 。 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 问 接地 调用 该 函数 本 身 。 
举例 如 下 : 
<?php 
recursion(5); 
function recursion($a) 
{ 
if ($a <= 10) { 
echo "$a "7 
recursion($a + 1); 
} 
} 
es 
这 段 代码 的 输出 是 数字 5，6，7，8，9，10。 在 此 段 代码 中 首先 调用 的 是 recursion0， 而 在 调用 
这 个 函数 的 过 程 中 ,如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 身 ， 这 就 是 函数 的 递归 调用 。 妖 
套 和 递归 在 使 用 PHP 进 行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 读者 举一反三 ， 清 晰 地 掌握 逻辑 
关系 后 才 可 以 进行 应 用 ， 和 否则 经 常 容 易 出 现 死 循 环 。 


二 本 MysQL 数 据 库 操作 


要 想 快 速成 为 PHP 网 页 编程 高 手 ， 核 心 掌握 MySQL 的 数据 库 操作 是 非常 重要 的 ， 一 般 PHP 实 
现 对 MySQL 的 操作 主要 包括 连接 、 创 建 、 插 入 、 选 择 、 查 询 、 排 序 、 更 新 以 及 删除 等 操作 ， 下 面 
就 分 别 介绍 一 下 实现 这 些 功能 的 函数 命令 。 


2.8.1 连接 数据 库 mysqli_connect() 


在 能 够 访问 并 处 理 数据 库 中 的 数据 之 前 ， 必 须 创建 到 达 数 据 库 的 连接 。 在 PHP 中 ,这 个 任务 通 
过 MySQLi 和 PDO 完 成 。 
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MySQLi 和 PDO 的 区 别 : 

PDO 应 用 在 12 种 不 同 数据 库 中 ，MySQLi 只 针对 MySQL 数 据 库 . 所 以 ， 如 果 用 户 的 项 目 需 
要 在 多 种 数据 库 中 切换 ， 建议 使 用 PDO， 这 样 只 需要 修改 连接 字符 囊 和 部 分 查询 语句 即 可 。 使 
用 MySQLi 进 行 连接 时 ， 如 果 使 用 不 同 的 数据 库 ， 需 要 重新 编写 所 有 代码 ， 包 括 查询 。 两 者 都 
是 面向 对 象 , 但 MySQLi 还 提供 了 API 接 口 。 两 者 都 支持 预 处 理 语句 ， 预 处 理 语句 可 以 防止 SQL 
注入 ， 对 于 Web 项 目的 安全 性 是 非常 重要 的 。 对 于 使 用 PHP+MySQL 的 组 合 开发 网 站 ， 建 议 还 
是 使 用 更 有 针对 性 的 MySQLi 连 接 方法 。 


下 面 是 mysqli_connect(O) 函 数 的 语法 格式 : 
mysqli_connect (servername,username,password, database); 

在 上 述 语 法 中 涉及 的 参数 说 明 如 下 。 

@ servername: 连接 的 服务 器 地 址 。 

@ username: 连接 数据 库 的 用 户 名 ， 默 认 值 是 服务 器 进程 所 有 者 的 用 户 名 。 
@ password: 连接 数据 库 的 密码 ， 默 认 值 为 空 。 

@ database: 连接 的 数据 库 名 称 。 


mysqli_connect(O) 函 数 如 果 成 功 执行 则 返回 一 个 MySQL 连 接 标识 ， 失 败 将 返回 False。 
在 下 面 的 例子 中 ， 我 们 在 一 个 变量 中 〈$conn) 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 接 





失败 ， 将 执行 die 部 分 ， 需 要 在 phpMyAdmin 中 预先 创建 一 个 数据 库 db_shop: 


<?php 
// 创建 连接 
$conn=mysqli_connect ("localhost", "root","","db shop"); 


// 检测 连接 


if (mysqli_connect_errno ($conn) ) 

{ 

echo "连接 MySQL 失败 : " . mysqli_connect_error (); 
} 

echo "连接 成 功 ”， 

?> 


脚本 一 结束 ， 就 会 关闭 连接 。 如 需 提 前 关闭 连接 ， 则 使 用 mysqli_close0 函 数 实现 。 在 默认 情 


况 下 , 脚本 执行 完毕 会 自动 断 开 与 服务 器 的 连接 , 但 是 使 用 mysqli_close() 函 数 则 可 以 在 指定 的 位 置 
来 关闭 连接 释放 内 存 。 
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<?php 
$conn = mysqli connect ("localhost","root"," "); 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 : ' . mysqli _error()); 

} 


mysqli_close(Sconn) 7 
2 


使 用 PDO 的 连接 代码 这 里 也 做 一 下 简单 的 介绍 : 
<?php 

$servername = "localhost"; 

$username = "username"; 

Spassword = "password"; 


// 创建 连接 
try { 
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$conn=new PDO("mysql:host=$servername;dbname=myDB", $username, $password); 


echo "连接 成 功 "; 
1 
catch (PDOException $e) 
{ 
echo $e->getMessage(); 
1 
大 


2.8.2 ”查询 数据 库 mysqli_query() 


CREATE DATABASE 语 句 用 于 在 MySQL 中 创建 数据 库 。 
语法 : 


CREATE DATABASE database name 


在 PHP 中 ， 使 用 mysqli_query0 函 数 来 向 MySQL 服 务 器 发 送 各 种 不 同 的 SQL 语 句 ， 例 如 insert、 





在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my_db 的 数据 库 : 


<?php 
$conn = mysqli_connect ("localhost","root"," "); 
if (!$conn) 
die(' 不 能 连接 数据 库 : ' . mysqli_error()); 
下 
if (mysqli_query(S$conn ,"CREATE DATABASE my_db") ) 
echo "Database created"; 
} 
else 
echo "Error creating database: " . mysqli error(); 
} 
mysqli_close($conn); 
2 


创建 的 my_db 数 据 库 如 图 2-23 所 示 。 


select、update 和 delete 等 。 这 里 也 要 注意 mysqli_query() 函 数 仅 对 SELECT、SHOW 、EXPLAIN 和 
DESCRIBE 语 句 返 回 一 个 资源 标识 符 ， 如 果 查 询 执 行 错误 则 返回 False。 对 于 其 他 类 型 的 SQL 语 句 ， 
mysqli_query() 在 执行 成 功 时 返回 True， 错 误 时 返回 False。 
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CREATE TABLE 语 句 用 于 在 MySQL 中 创建 数据 库 表 。 
语法 : 





为 了 执行 此 命令 ， 必 须 向 mysqli_query0 函 数 添 加 CREATE TABLE 语 句 。 
下 面 的 例子 展示 了 如 何 创建 一 个 名 为 Persons 的 表 ， 此 表 有 三 列 。 列 名 分 别 为 FirstName、 
LastName 以 及 Age: 
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2-24 ”Persons 表 创 建成 功 


在 创建 表 之 前 , 必须 先 选择 数据 库 。 通过 mysqli_select_db() 函 数 选取 数据 库 。 当 创建 varchar 类 
型 的 数据 库 字 段 时 , 必须 规定 该 字段 的 最 大 长 度 , 例如 varchar(15)。MySQL 各 种 数据 类 型 表 如 表 2-8 
至 表 2-11 所 示 。 
表 2-8 MySQL 数据 类 型 表 





数值 类 型 描述 
int(size) 仅 支 持 整 数 。 在 size 参 数 中 规定 数字 的 最 大 值 


smallint(size) 


tinyint(size) 


mediumint(size) 

bigint(size) 

decimal(size,d) 支持 带 有 小 数 的 数字 。 在 size 参 数 中 规定 数字 的 最 大 值 。 在 d 参 数 中 规定 小 数 点 右 侧 的 
double(size,d) 数字 的 最 大 值 

float(size,d) 





表 2-9 文本 数据 类 型 表 





文本 数据 类 型 描述 























char(size) 支持 固定 长 度 的 字符 串 〈 可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参 数 中 规定 固定 
长 度 

varchar(size) 支持 可 变 长 度 的 字符 串 〈 可 包含 字母 、 数 字 以 及 特殊 符号 )。 在 size 参 数 中 规定 最 大 
长 度 

tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 

text 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 

blob 

mediumtext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 16777215 个 字符 

mediumblob 

longtext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 

longblob 
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表 2-10 日 期 数据 类 型 表 





日 期 数据 类 型 描述 





date(yyyy-mm-dd) 支持 日 期 或 时 间 
datetime(yyyy-mm-dd hh:mm:ss) 
timestamp(yyyymmddhhmmss) 


time(hh:mm:ss) 





表 2-11 杂项 数据 类 型 表 


杂项 数据 类 型 描述 
enum(value 1,value?2,ect) enum 是 enumerated 列 表 的 缩写 。 可 以 在 括号 中 存放 最 多 65535 个 值 
set 与 squm 相 似 。 但 是 ，set 可 拥有 最 多 64 个 列表 项 目 , 并 可 存放 不 止 一 个 choice 


每 个 表 都 应 有 一 个 主键 字段 ， 主 键 用 于 对 表 中 的 行进 行 唯一 标识 。 每 个 主键 值 在 表 中 必须 是 
唯一 的 。 此 外 ,主键 字段 不 能 为 空 ， 这 是 由 于 数据 库 引擎 需要 一 个 值 来 对 记录 进行 定位 。 主 键 字 段 
永远 要 被 编 入 索引 ,这 条 规则 没有 例外 。 必 须 对 主键 字段 进行 索引 ， 这 样 数据 库 引擎 才能 快速 定位 
给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字 段 设 置 为 主键 字段 。 主 键 字 段 通常 是 ID 号 ， 且 通常 使 用 
AUTO_INCREMENT 设 置 。AUTO_INCREMENT 会 在 新 记录 被 添加 时 逐一 增加 该 字段 的 值 。 要 确 
保 主键 字段 不 为 空 ， 必 须 向 该 字段 添加 NOT NULL 设 置 。 

举例 如 下 : 

$sql = "CREATE TABLE Persons 

《 

PersonID int NOT NULL AUTO_INCREMENT, 

PRIMARY KEY (personID), 

FirstName varchar(15), 

LastName varchar(15), 

Age int 

J 

mysqli_ query($conn ,$sql); 























2.8.3 ”插入 数据 INSERT INTO 


INSERT INTO 语 句 用 于 向 数据 库 表 中 添加 新 记录 。 

语法 : 

INSERT INTO table name 
VALUES (valuel, value2,....) 

还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 

INSERT INTO table name (columnl, column2,...) 

VALUES (valuel, value2,....) 

SQL 语 句 对 大 小 写 不 敏感 。 INSERT INTO 与 insert into 相 同 。 为 了 让 PHP 执 行 该 语句 ， 必 须 使 用 

mysqli_query0 函 数 ， 该 函数 用 于 向 MySQL 连 接 发 送 查 询 或 命令 。 
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在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 有 三 个 列 ， 即 Firstname、Lastname 以 及 Age。 在 本 例 中 使 
用 同样 格式 的 表 ， 在 此 表 基 础 上 添加 了 两 个 新 记录 ， 代 码 输 出 结果 如 图 2-25 所 示 : 
<?php 
$conn = mysqli connect ("localhost","root",""); 
if (!$conn) 
die(' 不 能 连接 数据 库 : ' . mysqli error()); 
’ 
mysqli select dbl($conn , "my db"); 
mysqli query($conn , "INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('chen', ‘'yicai', '35°')"); 
mysqli query($conn , "INSERT INTO Persons (FirstName, LastName, Age) 
VALUES ('yu', ‘'heyun', '28°')"); 
mysqli close($conn); 
?> 
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下 机 结果 失 作 





EC 


see 
图 2-25 插入 数据 成 功 


2.8.4 获取 数据 mysqli_fetch_array() 


SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 : 
SELECT column name(s) FROM table name 


SQL 语句 对 大 小 写 不 敏感 ，SELECT 与 select 等 效 。 为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 使 用 
mysqli_query0 函 数 ， 该 函数 用 于 向 MySQL 发 送 查 询 或 命令 。 

在 PHP 中 ， 获 取 数 据 库 中 的 一 行 可 通过 函数 mysqli_fetch_array() 来 实现 ，mysqli_fetch_array() 
函数 会 将 从 结果 集中 获取 的 行 放 入 一 个 数组 中 ， 并 将 其 返回 。 

下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 〈* 字 符 表示 选取 表 中 所 有 数据 ) : 

<?php 

$conn = mysqli_ connect ("localhost","root",""); 

if (!Sconn) 

{ 


die(' 不 能 连接 数据 库 : ' . mysqli error()); 
和 
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mysqli_select db($conn,"my db"); 
$result = mysqli query($conn,"SELECT * FROM Persons"); 
while($row = mysqli fetch array ($result)) 
《 
echo Srow['FirstName'] . 
echo "<br />"; 
} 
mysqli close($conn); 
2 


"" . $row['LastName']; 





[和 一口 | X 

127.0.0.1 Sv 

Db | © | DNS 本 回 127.001/chapo5/fetchphp 识 127.0.0.11127.0.01/ myd + 抬 ” 
chen yicai 
yu heyun 
chen yicai 
yu heyun 





图 2-26 查询 并 显示 结果 
上 面 这 个 例子 在 $result 变量 中 存放 由 mysqli_query(0) 函 数 返 回 的 数据 。 接 下 来 ， 使 用 
mysqli_fetch_array() 函 数 以 数组 的 形式 从 记录 集 返 回 第 一 行 。 随 后 对 mysqli_fetch_array0 函 数 的 每 个 
调用 都 会 返回 记录 集中 的 下 一 行 。while 循 环 语句 会 循环 记录 集中 的 所 有 记录 。 为 了 输出 每 行 的 值 ， 
使 用 了 PHP 的 $row 变量 ($row['FirstName'] 和 $row['LastName'])。 


2.8.5 条 件 查询 WHERE 


如 需 选 取 匹配 指定 条 件 的 数据 ， 可 以 向 SELECT 语句 添加 WHERE 子 句 。 
语法 : 

SELECT column FROM table 

WHERE column operator value 


下 面 的 运算 符 如 表 2-12 所 示 ， 可 与 WHERE 子 句 一 起 使 用 。 
表 2-12 ”可 用 于 查询 的 运算 符 


























运算 符 说 明 

= 大 于 或 等 于 

二 小 于 或 等 于 

> 类 手 BETWEEN 介 于 一 个 包含 范围 内 
承重 LIKE | 搜索 匹配 的 模式 








由 于 SQL 语句 对 大 小 写 不 敏感 ，WHERE 与 where 等 效 ， 为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 使 用 
mysqli_query() 函 数 ， 该 函数 用 于 向 MySQL 连 接 发 送 查 询 和 命令 。 
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下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName='chen' 的 行 : 


<?php 
$conn = mysqli connect ("localhost","root",""); 
if (!$conn) 
4 
die(' 不 能 连接 数据 库 : ' . mysqli error()); 
和 
mysqli_select dbl($conn ,"my db"); 
$result = mysqli query($conn ,"SELECT * FROM Persons 
WHERE FirstName='chen'"); 


while($row = mysqli fetch array ($result)) 
长 
echo $row['FirstName'] . " " . S$row['LastName']7 
echo "<br />"; 


| 





3 
查询 的 结果 如 图 2-27 所 示 。 
6.1 [和 一口 XX 
© €<iC 全 全 器 127.0.0.1 动 乡 v 
Db |© | DNS 回 127.o0.1/chapo5/selectphF 朗 127001/11270011/mydlix |+ 应 


chen yicai 
chen yicai 








图 2-27 条 件 查询 并 显示 结果 


2.8.6 数据 排序 ORDER BY 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 
SELECT column name(s) 


FROM table name 
ORDER BY column name 


SQL 对 大 小 写 不 敏感 ，ORDER BY 与 order by 等 效 。 
下 面 的 例子 选取 Persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 : 


<?php 
$conn = mysqli_connect ("localhost","root",""); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : ' . mysqli error()); 
} 
mysqli_select dbl($conn,"my db"); 
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$result = mysqli query($conn,"SELECT * FROM Persons ORDER BY age") 
while($row = mysqli fetch array ($result)) 
echo $row['FirstName']; 
echo " " . $row['LastName']; 
echo " " . $row['Age']; 
echo "<br />"; 
} 
mysqli close($conn); 
ea 


可 单 [ 委 一 口 | 又 
127.0.0.1 EE 
回 127.001/chapo5/orderbyp 疲 127.0.0.11127.001/myd + 





chen yicai 35 
chen yicai 35 





图 2-28 排序 查询 并 显示 结果 


如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 〈1 在 9 之 前 ，a 在 p 之 前 ) 。 使 用 
DESC 关 键 词 来 设 定 降序 排序 (9 在 1 之 前 ，p 在 a 之 前 ) : 
SELECT column name(s) 


FROM table name 
ORDER BY column name DESC 


根据 两 列 进行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 有 第 一 列 相 
同时 才 使 用 第 二 列 : 


SELECT column name(s) 
FROM table name 
ORDER BY column namel, column name2 


2.8.7 ”更 新 数据 UPDATE 


UPDATE 语 句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table name 


SET column name = new value 
WHERE column name = some value 


由 于 SQL 对 大 小 写 不 敏感 ，UPDATE 与 update 等 效 。 为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 使 用 
mysqli query(0) 函 数 ， 该 函数 用 于 向 MySQL 连 接 发 送 查询 和 命令 。 
下 面 的 例子 可 以 更 新 Persons 表 的 一 些 数据 : 
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<?php 


$conn 


if (!$conn) 


die(' 不 能 连接 数据 库 : 


} 
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mysqli connect ("localhost","root",""); 


' . mysqli error()); 


mysqli_select dbl($conn ,"my db"); 


mysqli_ query ($conn, "UPDATE Persons SET Age 


WHERE FirstName "chen' AND LastName 


mysqli close($conn); 


138， 
Nee mj 








?> 
更 新 后 数据 表 如 图 2-29 所 示 。 
360 安 全 济 澳 类 8.1 束 间 | 曾 一 口 X 
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2:8.8 


WHERE column name 











图 2-29 数据 更 新 成 功 


删除 数据 DELETE FROM 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 


DELETE FROM table_name 


some_value 


SQL 对 大 小 写 不 敏感 ，DELETE FROM 与 delete from 等 效 。 为 了 让 PHP 执 行 上 面 的 语句 ， 必 须 
使 用 mysqli_query( ) 函 数 。 该 函数 用 于 向 MySQL 连 接 发 送 查 询 和 命令 。 
举例 如 下 : 


<?php 


$conn 


EE 
长 


die (" 不 能 连接 数据 库 : " 


} 


(!$conn) 


mysqli_connect ("localhost", "root",""); 


. mysqli error()); 


mysqli_select dbl($conn ,"my db"); 


79 


PHP 7.0 + MySQL 网 站 开发 全 程 实 例 


mysqli query($conn , "DELETE FROM Persons WHERE LastName="'yicai'"); 
mysqli close($conn); 
/二 


本 小 节 介绍 PHP 实 现 MySQL 数 据 库 的 一 些 常用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 编写 每 一 
行 代码 ， 养 成 规范 ， 方 便 后 面 内 容 的 学 习 。 
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全 程 实例 一 : 成 绩 查 询 系统 


进行 PHP 网 站 开发 的 环境 有 很 多 , 对 于 已 经 很 熟悉 HTML 语 言 和 PHP 的 设计 人 员 甚 至 可 以 直接 
使 用 记事 本 进行 代码 的 编写 工作 ; 对 于 新 手 来 说 可 以 使 用 Dreamweaver 配 合 MySQL 进 行动 态 系统 
的 开发 。 Dreamweaver 提 供 了 方便 的 图 形 化 界面 , 但 从 PHP 7.0 开 始 需 要 在 编辑 代码 窗口 中 手动 输 
入 一 些 程序 ， 才 能 够 与 MySQL 数 据 库 交互 ， 实 现 建立 数据 、 查 询 、 新 增 记录 、 更 新 记录 、 删 除 记 
录 等 操作 ， 实 现 PHP+MySQL 动 态 系统 的 开发 。 本 章 将 介绍 如 何 使 用 Dreamweaver 的 服务 器 行为 ， 
引导 读者 掌握 使 用 Dreamweaver 开 发 PHP 程 序 的 逻辑 方法 。 


本 章 的 学 习 重 点 : 

@ 在 Dreamweaver 中 进行 PHP 开 发 平台 的 搭建 
@ 搭建 PHP 成 绩 查 询 系统 开发 的 平台 

@ 检查 数据 库 记 录 的 常见 操作 

@ 编辑 记录 的 常见 操作 


PHP 7.0 + MySQL 网 站 开发 全 程 实例 


攻 对 成 绩 查询 系统 环境 


本 节 就 以 实例 “成 绩 查询 ”系统 的 形式 具体 介绍 Dreamweaver 中 的 服务 器 行为 的 使 用 方法 。 在 
开始 制作 一 个 PHP 网 站 之 前 ， 需 要 在 Dreamweaver 中 定义 一 个 新 站 点 。 在 “新 建站 点 ”中 可 以 显示 
现在 网 站 的 本 地 目录 、 测 试 的 路 径 等 信息 。 


3.1.1 查询 系统 设计 


“成 绩 查 询 ” 系 统 结构 主要 分 成 用 户 登 录入 口 与 找 回 密码 入 口 两 个 部 分 ， 其 中 index.php 是 这 
个 网 站 的 首页 。 

在 本 地 的 计算 机 设置 站 点 服务 器 ， 除 在 Dreamweaver CC 2017 的 网 站 环境 按 F12 键 来 浏览 网 页 
之 外 ， 还 可 以 在 浏览 器 输入 “http://127.0.0.1/phpweb/index.php” 来 打开 用 户 系统 的 首页 index.php， 
其 中 phpweb 为 站 点 名 。 

本 实例 制作 9 个 功能 页 面 ， 各 页 面 的 功能 如 表 3-1 所 示 。 





表 3-1 网 页 功能 表 


| deailpmp | 品 款 详细 成 绩 信 而 | 


(1) index.php: index.php 用 于 浏览 数据 库 内 的 记录 ， 为 detail.php 提 供 附 带 URL 参 数 ID 的 超级 
链接 ， 便 于 查看 详细 的 记录 信息 ， 如 图 3-1 所 示 。 



































































































































大 360 二 25 器 81 荣 单 [ 曾 一 | 口 XX 

€C 人 人 全 器 127.0.0.1 登 乡 v 

bb | O@ Dsseo 回 Php 或 续 查 询 系统 -让 ) 
PHP 成 绩 查询 系统 - 

序号 名 | 成 绩 作 

1 ltest1 21 100 详情 

2 test2 22 因 详情 

日 ltest3 2 6 详 

4 |test4 21 9 让 

昌 ests 22 ra 上 

共有 数据 10 条 ,每 页 显示 5 条， 第 1 页 / 共 2 页 ，1 2 











图 3-1 index.php 页 面 效果 
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(2) detailphp: detail.php 用 于 接收 由 index.php 传 来 的 URL 参 数 ID， 利 用 URL 参 数 筛选 数据 库 
中 的 记录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-2 所 示 。 








127.0.0.1 


[mE 
PH 成绩 查 询 系统 























人 年龄 | 成 绩 
22 ps 






































3-2 ”detail.php 页 面 效 果 


(3) update.php: update.php 用 于 接收 由 detaiLphp 传 来 的 URL 参 数 ID， 利 用 URL 参 数 筛选 数据 
库 中 的 记录 ， 单 击 “ 更 新 ”按钮 调用 saveupdate.php， 即 可 完成 数据 的 更 新 并 返回 原 网 页 ， 制 作 后 
的 效果 如 图 3-3 所 示 。 

在 360 关 全 Ri 吕 3.1 
|| 全 J 育 加 127.0.0.1 
bb | | Danwaneo 固 i 
PHP 成 绩 查询 系统 





姓名 年 抢 


[eatez 22 
更 新 | 重 置 



































图 3-3 update.php 页 面 效果 


(4) del.php: del.php 用 于 接收 由 detail.php 传 来 的 URL 参 数 ID， 利 用 URL 参 数 筛选 数据 库 中 的 
记录 ， 单 击 “ 删 除 ”按钮 调用 savedel.php， 即 可 完成 数据 的 删除 并 返回 首页 ， 制作 后 的 效果 如 图 3-4 
所 示 。 

知 360 雪 全 203 疾 8.1 

€ CO 魏 9 127.0.0.1 

b | © | Dessao 回 到 sx 
PHP 成 绩 查询 系统 














媳 齿 


























22 

















图 3-4 del.php 页 面 效果 
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当 实 现 一 个 PHP 系 统 功能 时 , 提前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 在 我 们 头脑 中 对 网 站 
要 有 一 个 雏形 ， 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 的 架构 规划 也 是 一 样 的 ， 要 有 哪些 
数据 表 、 字 段 ， 如 何 跟 网 页 配合 等 都 是 很 重要 的 工作 。 


3.1.2 ”创建 数据 库 


经 过 对 前 面 功 能 的 分 析 发 现 ， 数 据 库 应 该 包括 ID、 姓 名 、 年 龄 与 成 绩 4 个 字段 ， 所 以 在 数据 库 
中 必须 包含 一 个 容纳 上 述 信息 的 表 , 将 数据 库 命名 为 phppweb， 下 面 就 要 使 用 phpMyAdmin 软 件 建立 
网 站 数据 库 websql 作 为 任何 数据 查询 、 新 增 、 修 改 与 删除 的 后 端 支持 。 

创建 的 步骤 如 下 : 

步骤 014 在 浏览 器 中 输入 http://127.0.0.1/phpmyadmin/, 输 入 MySQL 的 用 户 名 和 密码 ( xammp 
默认 环境 下 可 以 直接 登录 ) 。 

步 又 024 单 击 “执行 ”按钮 即 可 进入 软件 的 管理 界面 ， 选 择 相关 数据 库 可 看 到 数据 库 中 的 
各 表 ， 可 进行 表 、 字 段 的 增删 改 ， 可 以 导入 、 导 出 数据 库 信息 ， 如 图 3-5 所 示 。 
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I 
图 3-5 软件 的 管理 界面 
步骤 034 单 击 日 8 命令， 打开 本 地 的 “数据 库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输 

入 数据 库 的 名 称 phpweb ， 单 击 后 面 的 数据 库 类 型 下 拉 按 钮 ， 在 弹出 的 下 拉 列 表 框 中 选择 

utf8_general_ci 选 项 ， 如 图 3-6 所 示 。 





避风 合 ， 
UTF8 是 数据 库 的 编码 格式 ， 通 常 在 开发 PHP 动 态 网 站 时 Dreamweaver 默 认 的 格式 就 是 
UTF8 格 式 ， 在 创建 数据 库 时 也 要 保证 数据 库存 储 的 格式 和 网 页 调用 的 格式 一 样 ， 这 里 要 介绍 
; 一 下 utf8_bin 和 utf8_general_ci 的 区 别 。 其 中 ci 是 case insensitive， 即 “大 小 写 不 敏感 ”，a 和 人 A 在 
字符 判断 中 会 被 当 作 一 样 的 ; bin 是 二 进 制 ，a 和 A 会 被 区 别 对 待 。 
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图 3.6 软件 的 管理 界面 
步骤 044 单 击 “创建 ” 按钮， 返回 “常规 设置 ” 页面 ， 在 数据 库 列表 中 就 已 经 建立 了 phpweb 
的 数据 库 ， 如 图 3-7 所 示 。 
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图 3-7 创建 后 的 页 面 


步 最 054 数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 是 
websql。 建 立 数据 库 后 ， 接 着 单 击 左边 的 phpweb 数 据 库 将 其 连接 上 ， 如 图 3-8 所 示 。 
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图 3-8 ”开始 建 数据 表 
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步 野 064 打开 “新 建 数据 表 ” 页 面 ， 在 “名 字 ” 文 本 框 中 输入 数据 表 名 websql， 在 “字段 
数 ” 文 本 框 中 输入 本 数据 表 的 字段 数 为 4， 表 示 将 创建 4 个 字段 来 存储 数据 ， 如 图 3-9 所 示 。 
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图 3-9 输入 数据 表 名 websql 和 字段 数 
步骤 D7 人 再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设 
置 数据 域 位 的 相关 数据 ， 如 图 3-10 所 示 。 各 字段 的 意义 如 表 3-2 所 示 。 这 个 数据 表 主 要 是 记录 每 个 
人 的 基本 数据 和 成 绩 。 
表 3-2 ”websql 数 据 表 
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图 3-10 设置 数据 库 字段 属性 


步骤 08 4 最 后 单 击 “ 保 存 ”按钮 ， 切 换 到 “结构 ”页 面 。 实 例 将 要 使 用 的 数据 库 建立 完毕 ， 
如 图 3-11 所 示 。 
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3-11 ”建立 的 数据 库 页 面 


步 野 094 为 了 页 面 制作 的 调用 需要 ， 可 以 先 在 数据 表 里 加 入 10 笔 数据 。 在 数据 表 手 动 加 入 
名 为 testl~test10 的 10 个 测试 姓名 ， 年 龄 和 成 绩 可 以 设置 不 同 的 数据 ， 如 图 3-12 所 示 。 
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图 3-12 ”加 入 10 笔 数据 


3.1.3 ”定义 Web 站 点 


在 Dreamweaver CC 2017 中 创建 一 个 “成 绩 查 询 ” 网 站 站 点 phpweb， 由 于 这 是 PHP 数 据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 3-3 所 示 。 


表 3-3 ”站 点 设置 的 基本 参数 


[mw yy 


MySQL 服 务 器 地 址 D:xampp \MySQL\ data\phpweb 
管理 账号 / 密码 root / 空 


下 所 库 名 和 
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创建 web 站 点 的 具体 操作 步骤 如 下 : 


步 又 014 在 D:xampp\htdocs 路 径 下 建立 phpweb 文 件 夹 ( 如 图 3-13 所 示 ) ， 本 实例 所 有 建立 
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图 3-13 建立 站 点 文件 夹 phpweb 


步骤 024 启动 Dreamweaver CC 2017， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 


“管理 站 点 ”对 话 框 ， 如 图 3-14 所 示 。 


和 


人 69 点 
EE 








-7 Bi 


CGE) GBD 





CG 
图 314 “管理 站 点 ”对 话 框 


步骤 034 单 击 “ 新 建站 点 ”按钮 打开“ 站 点 设置 对 象 ” 对 话 框 ， 左 边 是 站 点 列表 框 ， 其 
中 显示 可 以 设置 的 选项 。 进行 如 图 3-15 所 示 的 参数 设置 , 设置 站 点 名 称 为 phpweb， 本 地 站 点 文件 夹 


地 址 为 D:xampp\htdocs\phpweb。 
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步骤 044 


选项 卡 进行 如 图 


步 又 054 








第 3 章 ”全程 实 例 一 : 
站 点 设置 对 象 phpweb 六 
ES 人 
器 Dreamweaver 站 点 是 网 站 中 人 ra 站 

Css 预 处 理 各 让 站 檬 a Web 本 让 
》 高 级 设 半 

您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 去 和 名 称 * 

站 点 名 称 : phpweb 
本 地 让 点 文 件 夹 ， Dianpp htdocsphpweb 目 
Cm ) Cm )C 名 ) 














图 3-15 建立 phpweb 站 点 


3-16 所 示 的 参数 设置 。 


站 点 设 置 对 象 phpweb x 
和 十 王 
a 服务 器 名 称 : phpweb 
高 级 设置 
连接 方法 本 地 /3 ~ [| 
服务 器 文件 夫 : D:yempphtdocs [=] 





Web URL: (http://127.0,0, Uphpweb 











| 








Mh) CBDjDCw™w )| 梧 
图 3-16 “基本 ”选项 卡 设置 














成 绩 查询 系统 


单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 E 辐 ， 打 开 “ 基 本 ” 


设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选 项 (表示 是 使 用 PHP 开 发 的 
网 页 ) ， 其 他 的 保持 默认 值 ， 如 图 3-17 所 示 。 
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ks 本 允 旬 phpweb 
| = 
Css 远程 服务 器 
高 级 设置 加 维护 同步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 自用 文件 取出 功能 
回 打开 文件 之 前 取出 
取出 名 称 : 
电子 邮件 地 址 : 
测试 服务 器 


服务 器 模型 :| PHP MySQL 人 





编 错 服 


将 文件 自动 推送 到 而 式 服 务 器 
口 始终 自动 保存 相关 文件 

















图 3-17 设置 “高 级 ”选项 卡 
步骤 064 单 击 “ 保 存 ” 按 钮 ， 返回 “服务 器 ”设置 界面 ， 选 中 “测试 ” 单 选 按钮 ， 如 图 3-18 


所 示 
站 点 设置 对 象 phpweb 中 
[| 你 在 此 们 四 寺 反 承 web 上 的 而 的 了 务 器 。 此 对 话 械 的 设 鲁 来 
rr- Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 
》 高 级 设置 


名 地 址 鹿 闹 二 得 测试 








3 


保存 时 自动 推 本 
SM et wa 





sh ) Cm ) 
图 3-18 设置 “服务 器 ”参数 

步骤 D7 和 单 击 “ 保 存 ” 按 钮 ， 完 成 站 点 的 定义 设置 。 在 Dreamweaver CC 2017 中 就 已 经 拥有 
了 刚才 所 设置 的 站 点 Web。 单 击 “完成 ”按钮 , 关闭 “管理 站 点 ” 对话 框 , 这 样 就 完成 了 Dreamweaver 
CC 2017 测 试 Web 站 点 的 网 站 环境 设置 。 


这 里 要 说 明 一 下 ， 之 所 以 建立 Dreamweaver 的 站 点 配置 ， 是 为 了 方便 使 用 Dreamweaver 在 开发 
网 站 时 通过 单 击 “ 实 时 视图 ”窗口 可 以 在 编辑 窗口 的 上 部 分 实时 看 到 PHP 网 站 运行 的 效果 , 如 图 3-19 
所 示 。 这 也 是 本 书 推荐 初学 者 使 用 Dreamweaver 作 为 PHP 网 站 开发 编辑 器 的 主要 原因 之 一 ， 方 便 用 
户 所 见 即 所 得 ， 可 以 随时 进行 编辑 并 即时 看 到 制作 的 效果 。 
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图 3-19 ”Dreamweaver 制作 的 实时 窗口 显示 


3.1.4 ”建立 数据 库 连接 


完成 了 站 点 的 定义 后 ， 需 要 将 网 站 与 前 面 建立 的 phpweb 数 据 库 建立 连接 。 
网 站 与 数据 库 的 连接 步骤 如 下 : 
步 双 01 和 执行 菜单 栏 “ 文 件 ” 一 “新 建 ” 命 令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 conn.php 的 网 


页 ， 输 入 网 页 标题 “PHP 成 绩 查 询 系统 ”， 然 后 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 将 网 页 保存 ， 
如 图 3-20 所 示 。 
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日 田 日 日 口 回 
省- 竹 十 :是 声 


Rem 


可 sa -| 区 


图 3-20 创建 conn.php 空白 页 


步骤 024 conn.php 文 件 是 Dreamweaver 用 来 存放 MySQL 连 接 设置 的 文件 ， 在 大 多 数 的 PHP 编 
程 文件 中 都 喜欢 用 conn.php 文 件 名 来 命名 。 打 开 该 文件 并 使 用 “代码 ”视图 ， 输入 MySQL 的 连接 代 
码 ， 如 图 3-21 所 示 。 
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图 3-21 数据 库 连 接 设置 


在 这 个 文件 中 定义 了 与 MySQL 服 务 器 的 连接 (mysqli_connect 函 数 ) ， 包 括 以 下 内 容 : 
<?php 
// 建 立 数 据 库 连接 ; 

$conn=mysqli_connect ("localhost", "root","", "phpweb"); 
// 设 置 字符 为 btf-8，@ 抑 制 字符 变量 的 声明 提醒 。 
@ mysqli set charset ($conn,utf8); 
@ mysqli query ($conn,utf8); 
// 如 果 连 接 错误 显示 错误 原因 。 
if (mysqli_ connect errno($conn)) 
{ 

echo "连接 MySQL 失败 : " . mysqli_connect error(); 

二 
> 


其 中 ， 表 示 数 据 库 连接 的 代码 为 : 

@ localhost: MySQL 服 务 器 的 地 址 。 

@ phpweb: 连接 数据 库 的 名 称 。 

@ root: MySQL 用 户 名 称 。 

@ 空白 “”: MySQL 用 户 密码 。 这 里 使 用 环境 默认 是 空 


连接 后 才能 对 数据 库 进 行 查询 、 新 增 、 修 改 或 删除 的 操作 。 如 果 在 网 站 制作 完成 后 将 文件 上 
传 至 网 络 上 的 主机 空间 时 发 现 网 络 上 的 MySQL 服 务 器 访问 的 用 户 名 、 密 码 等 方面 与 本 机 设置 的 有 
所 不 同 ， 可 以 直接 修改 conn.php 文 件 。 


医 世 昌 动 态 查 询 功能 


使 用 PHP+Dreamweaver 可 以 利用 Dreamweaver 软 件 自 带 的 动态 服务 器 行为 快速 建立 一 些 基本 
动态 功能 ， 但 PHP 7.0 之 后 由 于 废弃 了 mysql.dll (推荐 使 用 mysqli 或 者 pdo_mysql) ， 就 无 法 再 使 用 
这 些 基 础 功能 了 。 需 要 在 Dreamweaver 中 单独 编写 PHP 代 码 来 实现 对 MySQL 数 据 库 的 操作 ， 主 要 包 
括 创 建 记 录 集 、 插入 记录 、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 集 分 页 等 常用 的 动态 服务 器 行为 。 
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3.2.1 创建 新 记录 集 


在 每 个 需要 查看 数据 库 记 录 的 页 面 中 皆 需 为 其 建立 一 个 MySQL 数 据 库 的 查询 “记录 和 集 ( 查 
询 ) ”， 从 而 可 以 让 Dreamweaver 知 道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 
要 的 内 容 一 样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建立 一 次 MySQL 连 接 ， 但 我 们 可 
为 同一 个 MySQL 数 据 库 连 接 建立 多 个 “记录 集 ”， 配 合 筛选 的 功能 达到 某 个 记录 集 只 包含 数据 库 
中 符合 某 些 条 件 的 记录 。 

下 面 以 系统 的 实例 实现 来 说 明 ， 具 体 的 步骤 如 下 : 


步 又 014 执行 菜单 栏 “ 文 件 ”一 “新建 ”命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 index.php 的 


网 页 , 输入 网 页 标题 “PHP 成 绩 查询 系统 ”， 然 后 执行 菜单 栏 “文件 ”一 “保存 ”命令 将 网 页 保存 。 
步骤 024 打开 index.php 文 件 后 ， 使 用 “代码 ”视图 ， 输 入 代码 如 下 : 
<?php 


$sqll=mysqli_ query($conn,"select * from websql order by ID asc limit "); 
// 设 置 websql 数 据 表 按 ID 升序 排序 查询 出 所 有 数据 
while($infol=mysqli_fetch_array($sql1)) 
// 使 用 mysqli_fetch_array 查 询 所 有 记录 集 ， 并 定义 为 $infol 

{ 
?> 


字段 的 功能 说 明 如 表 3-4 所 示 。 
表 3-4 ”字段 与 功能 说 明 





字段 说 明 

| mysqli query 函 数 | 一 般 用 ssqff 为 变量 定 久 | 
| mysali feteh array 函数 | 选择 所 建立 记录 集 作为 烙 组 | 
是 否 依照 革 个 字段 值 进行 排序 。 比 如 , 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 
前 面 位 置 ， 就 可 以 使 用 排序 的 功能 






order by ID asc 排序 


记录 集 使 用 到 的 就 是 SELECT 语句 ， 因 为 查询 出 来 的 结果 可 能 会 有 很 多 条 ， 所 以 称 为 记录 集 
( 合 ) ， 而 “筛选 ”部 分 则 对 应 WHERE 子 句 。 
其 程序 具体 分 析 如 下 : 


(1) 第 1 行 定 义 了 查询 数据 库 的 SQL 语 句 。 使 用 所 定义 的 SQL 语 句 对 数据 库 执行 查询 操作 
(mysqli_query()) ， 此 时 返回 的 结果 是 资源 标识 符 ， 还 不 能 被 使 用 。 

(2) 第 3 行将 前 面 查询 的 结果 以 关系 型 数组 的 形式 (mysqli_fetch_ array()) 传 至 变量 $info1， 
然后 就 可 以 使 用 $infol_ 记 录 集 名 称 [字段 名 称 ] 来 取得 记录 集 字段 值 。 


3.2.2 ”显示 所 有 记录 


要 将 记录 集 内 的 记录 (数据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步骤 如 下 : 
步 又 014 在 “文件 ”面板 中 打开 index.php， 在 网 页 中 制作 一 个 如 图 3-22 所 示 的 2x5 表 格 ， 然 
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后 在 表格 的 列 <td> 代 码 中 输入 如 下 代码 : 


<td><?php echo $infol['ID'];?></td><!-- 显 示 ID 字 段 --> 
<td><?php echo $infol['name'];?></td><!-- 显 示 name 字 段 --> 
<td><?php echo $infol['age'];?></td><!-- 显 示 age 字 段 --> 
<td><?php echo $infol['Result'];?></td><!-- 显 示 Result 字 段 --> 
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步 野 024 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 输入 相应 的 单元 格 后 , 单 击 [实时 视图 | 按钮 。 
视图 所 呈现 的 效果 与 使 用 浏览 器 打开 的 网 页 一 样 ， 原 本 仅 显示 { 记 录 集 名 称 .字段 名 称 } 的 部 分 将 会 
显示 出 记录 集 内 的 记录 ， 这 里 由 于 没有 设置 完整 的 重复 命令 ， 运 行 只 能 显示 空白 的 第 一 条 记录 集 ， 
如 图 3-23 所 示 。 
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图 3-23 显示 一 条 空白 的 数据 
步骤 034 再 单 击 一 次 [ 实时 视图 按钮 ， 将 页面 切换 到 [代码 视图 。 我 们 来 看 { 记 录 集 名 称 .字段 
名 称 } 部 分 的 代码 。 之 所 以 要 确认 选取 的 标签 为 <tr> ， 是 因为 重复 区 域 会 使 用 while 循 环 包围 所 作 
用 的 范围 。 而 需要 重复 的 仅 是 第 2 行 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 <tr > 标签 。 确 认 选 取 的 标 
签 正 确 ， 执 行 时 才 不 会 发 生 错 误 。 运 行 时 将 显示 所 有 的 记录 集 ， 如 图 3-24 所 示 。 
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图 3-24 ”显示 所 有 的 记录 集 





3.2.3 ”记录 集 的 分 页 


上 一 节 已 经 可 以 查询 记录 集中 所 有 的 记录 了 ， 那 剩 下 的 记录 如 何 显 示 出 来 呢 ?” 下 面 就 介绍 记 
录 集 分 页 功能 的 实现 方法 。 


步骤 014 在 index.php 页 面 代码 前 面 加 入 分 页 统计 查询 的 PHP 代 码 如 下 : 
<?php 
$sql=mysqli_query ($conn,"select count(*) as total from websql"); 
/ /建立 统计 有 记录 集 总 数 查询 ; 
$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 和 集 ; 
$total=$info['total']; 


// 定 义 变量 $total 值 为 记录 集 的 总 数 ; 
if($total==0) 
4 
echo "本 系统 暂 无 任何 查询 数据 !"; 


} 
A/ 如果 记录 总 数 为 0 则 显示 无 数据 ; 


else 


ra 


步骤 024 对 第 一 个 显示 所 有 记录 查询 进行 页 码 划 分 ， 实 现 的 代码 如 下 : 
<?php 


Spagesize=57 
// 设 置 每 页 显示 5 条 记录 ; 
if ($total<=$pagesize){ 
$pagecount=1; 


// 定 义 $pagecount 初 始 变 量 为 1 页 ; 
1 


if(($total%$pagesize) !=0){ 
$pagecount=intval ($total/$pagesize)+1; 
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// 取 页 面 统计 总 数 为 整数 ; 
}else{ 
Spagecount=Stotal/Spagesizey 


上 
if((@ $ GET['page'])==""){ 
Spage=17 
// 如 果 总 数 小 于 5 则 页 码 显示 为 1 页 ; 
}elsef{ 
$page=intval ($_GET['page']); 
// 如 果 大 于 5 条 则 显示 实际 的 总 数 ; 
有 
$sqll=mysqli query($conn,"select * from websql order by ID asc limit 
". ($page-1)*$pagesize.", $pagesize "); 
// 设 置 websql 数 据 表 按 ID 升 序 排序 查询 出 所 有 数据 ; 
while($infol=mysqli fetch array($sql1)) 
// 使 用 mysqli_fetch_array 查 询 所 有 记录 集 ， 并 定义 为 $infol; 


这 里 将 分 页 功能 定义 为 一 个 记录 集 ， 通 过 统计 之 后 即 可 进行 调用 ， 作 为 本 范例 中 建立 记录 集 
导航 条 。 


3.2.4 显示 记录 计数 


在 页 面 下 方 输入 “共有 数据 X 条 ， 每 页 显示 Y 条 ， 第 A 页 / 共 B 页 : ”， 建 立 起 记录 集 导 航 条 ， 
以 便 让 用 户 了 解 有 多 少 页 记录 ， 当 前 正在 浏览 第 几 页 。 

显示 记录 计数 的 步骤 如 下 : 

步骤 01 和 在 index.php 中 建立 一 个 表格 ,将 “共有 数据 X 条 ， 每 页 显示 Y 条 ， 第 A 页 / 共 B 页 : ” 
中 输入 显示 记录 数 的 PHP 代 码 如 下 : 


<table width="600" border="1" align="center" cellpadding="]1" cellspacing="1"> 
ES 
<td> 共 有 数据 
<?php 
echo $total;// 显 示 总 页 数 ; 
> 
&nbsp; 条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ， 
&nbsp; 第 &nbsp;<?php echo S$page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;// 打 印 总 页 码 数 ?>&nbsp; 页: 
<?php 
if ($page>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
{ 
2>: 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> / 
<a href="index.php?id=<?php echo $id;?>&gamp;page=<?php echo $page-1;?>" title=" 
前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 
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} 
if($pagecount<=4) { 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 
for ($i=1; $i<=$pagecount; $i++) { 
?> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 


,| 

}elsef 

for ($i=]1;$i<=4;$i++) { 

> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 
<a href="index.php?page=<?php echo S$page-1;?>" title=" 后 一 页 "><font 

face="webdings"> 8 </font></a> <a href="index.php?id=<?php echo 


$id;?>&amp;page=<?php echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : 
</font></a> 
<?php }?></td> 
</tr> 
</table> 


对 于 加 入 的 PHP 代 码 含义 在 代码 中 都 单独 进行 了 标注 。 


步骤 024 完成 后 ， 当 我 们 浏览 该 网 页 时 便 会 出 现 当前 共有 几 条 数据 ， 每 页 显示 的 条 数 ， 当 
前 是 第 几 笔 到 第 几 笔 的 提示 文字 ， 如 图 3-25 所 示 。 
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图 3-25 建立 导航 条 效果 


3.2.5 ”显示 详细 信息 


通常 一 个 动态 网 站 的 数据 量 是 比较 大 的 ， 很 多 时 候 并 不 会 一 开始 就 将 数据 库 所 有 字段 、 记 录 
都 显示 出 来 。 例如 一 个 新 闻 系 统 , 在 首页 只 会 显示 新 闻 的 日 期 与 标题 , 更 详细 的 新 闻 内 容 需 要 选择 
标题 后 进入 另 一 个 页 面 才能 显示 。 假设 显示 新 闻 标题 的 页 面 是 index.php, 而 显示 详细 新 闻 内 容 的 网 
页 名 称 为 detail.php。 当 在 index.php 中 单 击 标题 的 链接 后 , 此 时 该 超 链接 会 带 着 一 个 参数 到 detail.php， 
网 址 类 似 于 detailLphp?ID=1。 多 出 的 ID=1 是 一 个 变量 名 为 ID、 值 为 1 的 URL 参 数 。 当 detailphp 收 到 
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ID=1 的 URL 参 数 后 ， 便 利用 这 个 URL 人 参数 在 建立 记录 集 时 筛选 所 指定 的 新 闻 记 录 ， 并 将 记录 详细 
信息 显示 在 网 页 上 ,这样 就 构成 了 一 个 简单 的 新 闻 系 统 架构 。 要 筛选 指定 的 记录 可 以 在 SQL 中 使 用 
WHERE 子 句 。 
详细 页 的 制作 步骤 如 下 : 
步 又 014 使 用 Dreamweaver CC 2017 创 建 一 个 空白 detail.php 页 面 并 保存 。index.php 中 选择 要 
用 来 连接 到 详细 信息 页 面 的 部 分 (其 实 就 是 选择 要 在 哪里 建立 超级 链接 ) ， 在 本 例 中 选择 的 是 单 击 
“详情 ”文字 链接 ， 如 图 3-26 所 示 。 





























了 PHP 成 绩 查 询 系统 
6500 
[后 号 了 姓名 匡 苍 成 绩 妥 作 
加 图 加 四 上 人情 
共有 数据 曙 条 ， 每 页 显示 咖 条 , 第 田 贡 共 男 页 ,中 好 / 刀 胃 明 胃 呈 因 此 十 
[上 








[ 
图 3-26 单 击 首页 链接 到 detail.php 
步 野 024 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 回 ， 如 
图 3-27 所 示 。 





性 性 二 
《> HL 格式 四 无 ~ 类 (天 DBI 光 时 当 兴 机 @ 
肥 cs 10) 无 -人 “< 图 曝 @ Bp 
ED ~ Rw) 不 塘 行 (0) 口 友 果 黄色 (G) 站 于 (CC Rt 

em 江面 直 mm WA 高 m) 村 暂 四 口 











图 3-27 ”建立 链接 设置 
步骤 034 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 detaiLphp， 如 图 3-28 所 示 。 


x 
个 并 wmpp » hidocs ,phpweb » vo meph 


组 从 ”新 时 文 H 闪 

















图 3-28 设置 链接 的 文件 
步 最 044 如 果 只 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 并 没有 附带 URL 参 数 ， 因 此 要 设置 超级 
链接 要 附带 的 URL 参 数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 ID， 接 收 上 一 页 传递 过 来 的 ID 值 。 
步 最 054 地 址 变 成 detailLphp?ID=<2php echo Sinfol[TD']:?>， 如 图 3-29 所 示 。 


98 


第 3 章 “全 程 实例 一 : 成 绩 查询 系统 





<td><a href="detail.php?ID=<?php echo $infol['ID'];?>"> 详 情 </a></td> 
<!-- 设 置 跳 转 并 传递 1D 值 --> 








3 pee 
而 性 去 
Om 检 t(F) 无 @ 
县 css DO 元 ~ 中 [3 
民 加 和 i 格 水平 外。 时 A - RW 太行 (0) 口 。 背 景 顶 (6) 中 CC sat ) 

-一 让 要 直 m 蚜 \ ~ 豆 H 标量 四 口 上 











图 3-29 完成 后 的 链接 地 址 

步骤 064 设置 完成 后 ， 可 以 在 浏览 器 打开 index.php 页 面 。 在 浏览 器 下 方 的 状态 栏 上 可 以 看 

到 每 一 条 记录 的 链接 都 带 着 URL 参 数 ID， 其 值 是 每 条 记录 的 ID， 如 图 3-30 所 示 。 
> ”OO 127.00.1/ph 让 二 世 - 个 








共有 数据 10 条 ， 每 页 显示 5 条 ， 第 1 页 / 共 2 页 ，12 





http//127.00.1/phpweb/detailphp?ID=1 








图 3-30 单 击 链接 的 属性 显示 
前 面 已 经 完成 index.php 页 面 的 制作 ， 下 面 来 设计 接收 URL 参 数 的 detail.php 页 面 ， 看 看 如 何 用 
收 到 的 参数 来 筛选 指定 的 记录 。 
步骤 01 和 打开 detail.php 页 面 后 输入 的 PHP 代 码 如 下 : 


<?php require once('conn.php'); ?> 
// 调 用 数据 库 连接 文件 实现 连接 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>PHP 成 绩 查 询 系统 </title> 
<style type="text/css"> 
.aline center { 

text-align: center; 
} 
-Ca 

text-align: center; 
</style> 
</head> 
<body class="ca"> 
<P class="aline_center">PHP 成 绩 查询 系统 </p> 
< YX> 
<table width="600" border="1" align="center" cellpadding="1" cellspacing="1"> 

<tr> 

<td> 序 号 </td> 
<td> 姓 名 </td> 
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<td> 年 龄 </td> 
<td> 成 绩 </td> 
<td> 编 辑 </td> 
</Er> 
<?php 
$ID=@ $_GET['ID']; 
// 设 置 $ID 值 为 前 页 传 过 来 的 ID 值 ， 使 用 $_GETT[] 函数 实现 
$sql=mysqli query($conn,"select * from websql where ID='".$ID."'"); 
/ /建立 数据 库 条 件 查 询 ， 查 询 条件 为 ID='" .$ID."'" 
$info=mysqli fetch array($sql); 
?> 
<tr> 
<td><?php echo $info['ID'];?></td> 
<td><?php echo $info['name'];?></td> 
<td><?php echo $info['age'];?></td> 
<td><?php echo $info['Result'];?></td> 
<td><a href="update.php?ID=<?php echo $info['ID'];?>"> 更 新 </a> / <a 
href="del .php?ID=<?php echo $info['ID'];?>"> 删 除 </a></td> 
xr 
</table> 
< 
<P>&nbsp;</P> 
</body> 
</html> 


步骤 024 记录 集 建立 完毕 后 ， 可 以 把 各 个 字段 “插入 ”页 面相 应 的 单元 格 中 ， 完 成 的 页 面 
如 图 3-31 所 示 。 


DW xl Wek gEv EN) IRM mol Wars) gOW ea Se. | gl ‘= 
RH 


dottphpr x prpweo -Dnppv ldocMphoueti eid pp | 
~ 六 CC Libranes 僧人 C55 发放 a 
RD ro 了 


0, GE ~ 四 ~ 
人 4. PHP 成 绩 查 询 系统 #10 
jy gf 
太史 ee | 
是 L 加 加 二 IEE ma 














< 四 :个 本 地 四 入 中, 总 失 1082 人 字 节 。 
BD. 膨 左 日 mm ez ~ ms zl | om 证 =， 


”图 3-31 制作 的 详细 页 面 


步骤 034 完成 后 直接 按 F12 键 在 浏览 器 中 打开 detailphp, 发 现 内 容 是 空白 的 ， 如 图 3-32 所 示 。 
这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没有 带 URL 参 数 ， 当 然 记 录 集 里 就 不 会 有 任何 内 容 了 。 





100 


第 3 章 ， 全 程 实例 一 : 成 绩 查询 系统 





人 127.0.0.1/phpweb/detail.php wel 三 久 从 
了 HP 成 绩 查 询 系统 





序号 名 辑 

















图 3-32 显示 为 空白 
步骤 044 直接 在 网 址 后 加 上 URL 变 量 ID， 其 值 可 以 选 1~10 的 任何 一 个 值 ， 如 这 里 输入 6， 然 
后 按 Enter 键 ， 网 页 显示 的 结果 如 图 3-33 所 示 。 





€ 人 > © | 12700VphpwebldeesilpFr 支 由 三 当 地 
































图 3-33 ”URL 参数 ID=6 时 的 详细 页 面 


步 坚 005 和。 在 index.php 中 ， 每 一 条 记录 的 网 址 都 带 有 特定 的 参数 链接 到 detail.php， 如 图 3-34 
所 示 。 


| 




















httpy/127.00.1/phpweb/cetailphp?lD=8 


图 3-34 单 击 编 号 链接 


这 里 如 果 不 以 “详情 ”作为 主 链接 也 是 可 以 的 ， 也 可 以 使 用 标题 作为 链接 。 单 击 某 个 新 闻 标 
题 即 可 打开 相应 的 详细 页 面 采用 的 就 是 这 种 技术 。 


医 攻 量 编辑 记录 功能 


数据 库 记录 在 页 面 上 的 显示 、 重 复 、 分 页 、 计 数 、 显 示 详 细 信 息 的 操作 已 经 介绍 完毕 ， 本 节 
将 介绍 在 Dreamweaver CC 2017 中 进行 增加 、 修 改 以 及 删除 记录 的 操作 。 


3.3.1 增加 记录 功能 


在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 且 附 加 了 “自动 编号 ”属性 ， 因 此 在 新 增 记 
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录 时 不 必 考 虑 ID 字段 ， 只 需 增加 3 个 值 即 可 。 
实现 的 步骤 如 下 : 


步 又 014 创建 一 个 空白 的 php 网 页 ， 并 命名 为 add.php， 先 添加 一 个 表单 ， 再 插入 一 个 4x2 表 
格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-35 所 示 。 


Dw xz mae sav sn IRm stn SG gow wa He- gl [=lol * 











CC 
me ~ wr ~ a 05 加 [DO BR 


。 图 3-35 建立 表单 并 设计 网 页 

当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必须 置 于 表单 内 ， 在 单 击 按钮 
后 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。 

步骤 024 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 在 “属性 ”面板 为 其 命名 ， 分 别 是 
姓名 name、 年 龄 age、 成 绩 Result， 注 意 在 设计 时 要 与 记录 集 字 段 名 称 一 一 对 应 ， 如 图 3-36 所 示 为 成 





























绩 Result 的 文本 框 属性 设置 。 
时 住 
串 文本 域 字符 更 度 人) 类 型 加 单行 (5) 。 〇 多 行 如 。 〇 密码 (P) 。 类 (0) [无 v 
Result 最 多 字符 教 初始 值 (I) 多 
DM) 
口 8 次 全 
图 3-36 命名 文本 域 


当 表 单元 素 的 命名 与 记录 集 字段 相符 合 时 ， 在 做 “新 增 记录 ”“ 更 新 记录 ”时 PHP 会 自动 
将 表单 元 素 与 记录 集 字 段 相 匹配 ， 同 时 也 方便 编程 人 员 在 做 修改 时 能 快速 找到 相应 的 字段 。 


步骤 034 设置 完成 后 , 在 页 面 中 加 入 一 个 跳 转 和 判断 的 命令 , 其 中 action="saveadd.php" 用 于 
提交 表单 后 提交 到 saveadd.php 代 码 页 进行 处 理 ，onSubmit="return chkinput(this)" 是 在 本 页 的 前 面 加 
入 表单 验证 的 功能 ， 即 不 能 提交 空白 数据 ， 具 体 所 加 入 的 位 置 如 下 : 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 


<title> 添 加 记录 </title> 
<style type="text/css"> 
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-aline Center { text-align: center; 
} 
</style> 
</head> 
<script language="javascript"> 
function chkinput (form) 
{ 
if (form.name.value=: 





alert ("请 输入 姓名 !" 
form.name.select () 
return (false); 





if(form.age.value=="") 


alert ("请 输入 年 龄 !"); 
form.age.select (); 
return (false); 


if(form.Result .value=="") 


alert ("请 输入 年 龄 1")， 
form.Result.select (); 
return (false); 
} 
return (true); 
y 
</script> 
<body> 
<p class="aline_center">PHP 成 绩 查询 系统 </p> 
<hr /> 
<form name="forml" method="POST" action="saveadd.php" onSubmit="return 
chkinput (this)"> 


<table width="300" border="1" align="center" cellpadding="1" 
cellspacing="1"> 
<tr> 


<td width="84"> 姓 名 : </td> 
<td width="203"><input type="text" name="name" id="name" /></td> 
</tr> 
<tr> 
<td> 年 龄 : </td> 
<td><input type="text" name="age" id="age" /></td> 
Er 
<tr> 
<td> 成 绩 : </td> 
<td><input type="text" name="Result" id="Result" /></td> 
</tr> 
<tr> 
<td>gnbsp;</td> 
<td><input type="submit" name="button"” id="button" value=" 提 交 "” /> 
<input type="reset" name="button2"” id="button2"” value=" 重 置 " /></td> 
</tr> 
</table> 
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</form> 

hr /> 
<p>gnbsp;</p> 
</body> 
</html> 


步骤 044 提交 到 的 saveadd.php 网 页 是 纯 PHP 代 码 ， 主 要 功能 是 将 提交 的 表单 数据 插入 
MySQL 数 据 库 中 ， 实 现 的 PHP 代 码 如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$name=$_POST['name']; 
$age=$_POST['age']; 
$Result=$_POST['Result']; 


mysqli query($conn,"insert into websql (name,age,Result) values ('$name', 
'$age','$Result')"); 


echo "<script>alert (' 添 加 成 功 !');history.back();</script>"; 
// 用 script 脚 本 语言 实现 插入 后 提醒 “添加 成 功 ”，history .back() ;实现 跳 转 回 原 页 的 功能 
?> 


步骤 05Q 和 直接 按 F12 键 在 浏览 器 中 打开 网 页 ， 输入 值 如 图 3-37 所 示 ， 单 击 “提交 ”按钮 尝试 
新 增 一 笔记 录 。 
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图 3-37 输入 记录 数据 


步骤 064 单 击 “ 提 交 ” 按 钮 后 ， 网 址 将 从 add.php 转 至 index.php。 单 击 网 页 下 方 的 分 页 导航 
条 的 “最 后 一 页 ”链接 ( 这 里 是 单 击 数字 3 链接 ) ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-38 所 示 。 
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| 共有 数据 11 条 ， 每 页 显示 5 条 ， 第 3 页 / 共 3 页 WW/«123Y、 























图 3-38 增加 记录 后 的 效果 
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3.3.2 ”更 新 记录 功能 
更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根据 需要 进行 更 新 的 操作 。 这 里 我 们 会 用 前 面 已 经 使 


用 到 的 detail.php 文 件 。 
更 新 记录 功能 的 操作 步骤 如 下 : 


步骤 01 和 《 打开 detail.php 网 页 后 ， 选 择 链接 文字 “更 新 ”， 如 图 3-39 所 示 。 


DW xmn San sm SMN IRM aatol sa OW mee 














一 CW pe SN 171 
Dov ss nny 到 : 


FP-* 
图 3-39 选择 链接 文字 





步骤 02 在 “属性 ”面板 中 单 击 如 图 3-40 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 参 
数 的 超级 链接 。 
尾 性 至 
> HL 格式 (无 ~ 类 (无 vB7 汪 中 兰 兰 村 中 
县 css IO 无 ~ 匀 纺 品 ~ 目标 (S) 
司 吾 | “单元 格 水 平 (z) 黑 认 ~ 宽 (Ww) 不拘 行 (0) 口 。 背 景 颜色 (6) 全 J [asxt] (页 面 属 
ED 让 重 直 m 点 人 ~ 高 H) 标题 四 口 











图 3-40 单 击 “ 浏 览 文件 ”图 标 
步骤 03 输入 用 来 更 新 记录 使 用 的 update.php 页 面 ， 为 其 建立 名 称 为 ID、 值 是 记录 集 ID 字 段 
值 的 URL 参 数 。 
步 最 044 完成 后 的 链接 地 址 如 图 3-41 所 示 。 


update.php?ID=<?php echo $info['ID'];?> 
// 传 递 ID 到 update .php 页 面 


























屋 性 
OH 格 zt(F) 无 > 类 (无 了 BJ 党 符 符 壮 本 中 

旧 css IO 元 ~ 负 慷 人 9 [wdatephpzpD=<?php edh ~| 镶 加 目标 (G) ~ 

全 于 | 单元 格 “水 平 (2 默认 ~ 宽 (W) 换行 (9) 口 ”背景 颜色 (c) [| (“页面 属 
加 站 放 要 直 (T) 点 人 ~ 高) 标题 刁 口 


图 3-41 传递 ID 至 update.php 
步 最 054 创建 update.php 空 白文 档 ， 该 页 面 的 设计 与 详细 信息 页 面 detailphp 相 同 ， 都 是 要 利 
用 接收 到 的 URL 参 数 筛选 指定 记录 。 使 用 PHP 设 置 查询 记录 和 集 代码 如 下 : 
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<?php 
$ID=@ $_GET['ID']; 
$sql=mysqli query($conn,"select * from websql where ID="'".$ID."'"); 
$info=mysqli fetch array($sql); 
二 
步骤 064 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 按 钮 设置 完成 ， 在 “ 绑 定 ”面板 中 将 记录 集 
内 的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 如 图 3-42 所 示 。 由 于 ID 是 主键 ， 不 能 随便 变更 主键 的 
值 ， 因 此 这 里 的 ID 部 分 是 直接 显示 为 文本 字段 ， 其 他 为 输入 文本 。 


了 HP 成 绩 查询 系统 




















| Cophp echo $inf | Cophp echo $inf 
更 新 ， 重 置 











图 342 ， 绑 定 字段 
步 双 07 和 外、 同样 需要 对 在 单 击 “ 更 新 ”按钮 时 进行 一 个 表单 判断 ， 不 能 让 姓名 、 年 龄 、 成 绩 
三 个 字段 为 空 ， 完 成 整 页 的 代码 如 下 : 


<?php require once('conn.php'); ?> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 更 新 页 面 </title> 
<style type="text/css"> 
.aline center { text-align: center; 
} 
-dc { 
text-align: center; 
} 
</style> 
</head> 


<body> 
<P class="aline_center">PHP 成 绩 查询 系统 </p> 
<hr /> 
<script language="javascript"> 
function chkinput (form) 
{ 


if (form.name.value=="") 


alert ("请 输入 姓名 !"); 
form.name.select (); 
return (false); 


if(form.age.value=="") 
alert ("请 输入 年 龄 !"); 


form.age.select (); 
return (false); 
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ifE(form.Result.value=="") 


alert (" 请 输入 年 龄 !") 7 
form.Result.select (); 
return (false); 
} 
return (true); 
} 
</script> 
<form name="forml" method="post" action="saveupdate.php" onSubmit="return 
chkinput (this)"> 
<table width="600" border="1" align="center" cellpadding="1" cellspacing= 
Wl Be 
<tr> 
<td> 序 号 </td> 
<td> 姓 名 </td> 
<td> 年 龄 </td> 
<td> 成 绩 </td> 
</tr> 
<?php 
$ID=@ $_GET['ID']; 
$sql=mysqli query($conn,"select * from websql where ID='".$ID."'"); 
$info=mysqli fetch array($sql); 
?> 
<tr> 
<td><?php echo $info['ID'];?></td> 
<input name="ID" type="hidden" id="ID" value="<?php echo $info['ID']?>" 
size="16" /> 


<!-- 加 入 ID 隐藏 域 使 用 表单 传递 时 能 把 ID 值 正 确 传 给 下 一 页 --> 


<td><input name="name" type="text" id="name" value="<?php echo 
$info['name']?>" size="16" /></td> 
<td><input name="age" type="text" id="age" value="<?php echo 


$info['age']?>" size="16" /></td> 
<td><input name="Result" type="text" id="Result" value="<?php echo 
$info['Result']?>" size="16" /></td> 
</tr> 
发 万世 之 
<td colspan="4" class="dc"><input type="submit" name="button" id="button" 
value=" 更 新 "” /> 
<input type="reset" name="button2" id="button2"” value=" 重 置 " /></td> 
REX> 
</table> 
</form> 
hr/ 
<p>gnbsp;</p> 
<p>gnbsp;</p> 
</body> 
</html> 


步 又 084 创建 saveupdate.php 网 页 ,使 用 update 函 数 实现 对 表格 数据 的 更 新 ， 具 体 的 PHP 代 码 
加 TT: 
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<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
$ID=$_POST['ID']; 
$name=$_POST['name']; 
$age=$_POST['age']; 
$Result=$_POST['Result']; 
include ("conn.php"); 
mysqli query($conn,"update websql set name='$name',age='$age',Result= 
'$SResult' where id='$ID'"); 
echo "<script>alert (' 修 改 成 功 !') ;history.back();</script>"; 
?> 


步 又 094 最 后 在 浏览 器 中 打开 index.php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail.php， 再 在 详 
情 页 面 选择 “更 新 ”链接 ， 如 图 3-43 所 示 。 





6 360= 人 a1 < 东单 | 曾 一 口 ， 勾 

CO 全 器 127.0.0.1 FY 

D | © | DSSB60 回 pHpzg 项 音 鹿 系统 十 Bo 
PHP 成 绩 查询 系统 


















序号 姓名 性 龄 成 绩 
Ls lhestll lz lss 医 














图 3-43 ”选择 “更 新 ”链接 
步骤 104 在 update.php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 ， 而 ID 文本 字段 是 不 能 被 修改 
的 ， 更 改 完 成 后 单 击 “ 更 新 ”按钮 ， 如 图 3-44 所 示 。 





全 360 安 全 济 才 用 81 < 可 单 | 曾 一口 X 
CO 位 器 127.0.0.1 FE 
| ©O DSSao wr x | 尼 >” 




















图 3-44 修改 数据 
步 又 114 返回 到 index.php， 检 查 记录 是 否 被 正确 更 新 ， 如 图 3-45 所 示 。 
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本 360 六 全 ;5 右 81 




















< 系 单 | 曾 一 口 Xx 
€C 人 全 器 127.0.0.1 -Ahd 
lb》 | © Dasssao 加 php 二 和 红 x | 十 拓 ” 

PHP 成 绩 查询 系统 
Ea ES 民 作 
14 [test11 2 这 全 
| 共有 数据 11 条 ， 每 页 显示 5 条 ， 第 3 页 / 共 3 页 /W123 






























































图 3-45 完成 更 新 的 功能 页 面 
这 部 分 的 程序 代码 与 插入 记录 基本 相同 , 差别 只 在 于 隐藏 字段 的 名 称 不 同 , 使 用 的 是 UPDATE 
语句 。 


3.3.3 ”删除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 delete〈 删 除 记录 ) 命令 即 可 实现 。 具 体 的 实 
现 步 骤 如 下 : 


步 坚 01 和 使 用 超级 链接 带 着 URL 参 数 转 到 删除 页 面 del.php。 首先 在 detaiLphp 中 选中 “删除 ”， 
在 “属性 ”面板 中 建立 链接 ， 如 图 3-46 所 示 。 








图 3-46 设置 “删除 ”链接 。 


步 又 024 在 “属性 ”面板 中 单 击 如 图 3-47 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 参 
数 的 超级 链接 。 

















层 性 豆 
《> HL 打工 四 无 ~ 类 (无 小 BJ 党 在 符 举 本 

怒 css IO 无 ~ 镑 廊 QD ~ 图 目标 (G) 

全 可 | 单元 格 。 水平 中。 对 认 ~ 实 (W) 不拘 行 (0) 口 背景 汤色 (6) [J 页 面 属 
乒 | [maxf#] 

| 一 六 委 直 (Tm) 由 人 ~ 高 m 村 是 田口 


图 3-47 单 击 “ 浏 览 文件 ”图 标 
步 又 034 输入 用 来 删除 记录 使 用 的 delphp 页 面 ， 为 其 建立 名 称 为 ID、 值 是 记录 集 ID 字 段 什 
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的 URL 参 数 。 
步骤 044 完成 后 的 链接 地 址 如 图 3-48 所 示 .。 


del.php?ID=<?php echo $info['ID'];?> 
// 传 递 ID 到 de1l .php 页 面 


属性 至 
CF Hm 4 四 天 ©® 
县 css DO 元 ~ 











面 面 | 单元 格 “水 平 (2) 驯 人 ~ 宽 (w) 不 接 行 (0) 口 。 背 景 颜 色 (6) 厂 -| E 
站 要 直上 四 ”点 人 ~ 高 H) 标题 提 口 本 
图 3-48 传递 ID 至 del.php 
步骤 054 创建 del.php 空 白文 档 , 使 用 PHP 设 置 查询 记录 集 代 码 ， 实 现 功 能 的 PHP 代 码 已 经 在 
网 页 中 标注 出 来 : 


<?PhP require once('conn.php'); ?> 














<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 删 除 页 面 </title> 

<style type="text/css"> 

“aline center { text-align: center; 

} 

sc 


text-align: center; 
} 
</style> 
</head> 
<body> 
<p class="aline_center">PHP 成 绩 查询 系统 </p> 
<hr/> 
<form name="forml" method="post" action="savedel.php""> 
<table width="600" border="1" align="center" cellpadding="1" 
cellspacing="1"> 
<tr> 
<td> 序 号 </td> 
<td> 姓 名 </td> 
<td> 年 龄 </td> 
<td> 成 绩 </td> 
</tr> 
<?PhP 
$ID=$_GET['ID']; 
$sql=mysqli query ($conn,"select * from websql where ID='".$ID."'"); 
$info=mysqli fetch array ($sql); 
?> 
// 查询 记录 和 集 记 录 
xt 
<td><?php echo $info['ID'];?></td> 
<input name="ID" type="hidden" id="ID" value="<?php echo 
$info['ID'] ?>" size="16" /> 


<!-- 加 入 ID 隐藏 域 使 用 表单 传递 时 能 把 ID 值 正 确 传 给 下 一 页 --> 
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<input type="hidden" name="id" value="<?php echo $info['ID'];?>"> 
<td><?php echo $info['name']?></td> 
<td><?php echo $info['age']?></td> 
<td><?php echo $info['Result']?></td> 
</tr> 
<tr> 
<td colspan="4" class="dc"><input type="submit" name="button" 
id="button" value=" 删 除 ” /></td> 
</tr> 
</table> 
</form> 
2 
<p>&nbsp;</p> 
<p>&nbsp;</p> 
</body> 
</html> 


步骤 064 、 最 后 创建 savedel.php 网 页 代码 ， 使 用 delete 命 令 实 现 数 据 库 的 删除 操作 。 并 使 用 
header("location:index.php"): 命 令 实现 删除 成 功 后 跳 转 到 首页 。 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

include ("conn.php"); 

$ID=$_POST['ID']; 

mysqli_query ($conn,"delete from websql where id="'$ID'"); 

echo "<script>alert (' 删 除 成 功 !');</script>"; 

header ("location:index.php"); 

ea 


本 章 学 习 了 最 基本 的 PHP 常 用 服务 器 行为 的 操作 和 使 用 , 并 且 了 解 了 原始 程序 代码 的 意义 。 在 
后 面 的 章节 中 , 如 用 户 管理 系统 、 留 言 簿 管理 系统 、 新 闻 管理 系统 等 的 实现 都 将 用 到 这 些 基本 操作 。 
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在 网 站 的 建设 开发 中 ， 第 一 个 要 接触 的 就 是 用 户 管理 系统 的 开发 ， 即 网 站 提供 给 会 员 注册 并 
能 登录 进行 一 些 操作 的 基本 功能 。 一 个 典型 的 用 户 系统 一 般 应 该 有 用 户 注册 功能 、 资 料 修改 功能 、 
取 回 密码 功能 ， 以 及 用 户 注销 身份 等 功能 。 本 章 将 以 前 介绍 的 知识 加 以 灵活 应 用 。 该 实例 中 主要 用 
到 创建 数据 库 和 数据 库 表 、 建 立 数据 源 连 接 、 建 立 记录 集 、 创建 各 种 动态 页 面 、 添 加 重复 区 域 来 显 
示 多 条 记录 、 页 面 之 间 传递 信息 、 创 建 导航 条 、 隐 藏 导航 条 链接 等 技巧 和 方法 。 


本 章 的 学 习 重 点 : 

用 户 管理 系统 网 站 结构 的 搭建 

创建 数据 库 和 数据 库 表 

建立 数据 库 连 接 

掌握 用 户 管理 系统 中 页 面 之 间 信 息 传递 的 技巧 和 方法 
用 户 管理 系统 常用 功能 的 设计 与 实现 
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二 村 用 户 管理 系统 的 规划 


在 开发 用 户 管理 系统 之 前 要 做 好 整个 系统 的 规划 ， 比 如 在 注册 时 需要 采集 哪些 资料 、 是 否 提 
供 在 线 修改 密码 等 操作 。 这 样 方便 后 面 整 个 系统 的 开发 与 制作 , 本 节 就 介绍 一 下 用 户 管理 系统 的 整 
体 规划 工作 。 


4.1.1 页 面 规划 设计 


“用 户 管理 ”的 系统 分 为 用 户 登 录入 口 与 找 回 密码 入 口 两 个 部 分 ， 其 中 index.php 是 这 个 网 站 
的 首页 。 在 本 地 的 计算 机 设置 站 点 服务 器 ,在 Dreamweaver CC 2017 的 网 站 环境 按 F12 键 来 浏览 网 页 ， 
或 者 在 浏览 嚣 中 输入 “http://127.0.0.1/member/index.php” 来 打开 用 户 管理 系统 的 首页 index.php， 其 
中 member 为 站 点 名 。 


实例 共有 12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 功能 如 表 4-1 所 示 。 
表 4-1 用 户 管理 系统 网 页 功能 表 











页 面 功能 

index.php 用 户 开 始 登 录 的 页 面 
welcome.php 用 户 登 录 成 功 后 显示 的 页 面 
loginfail.php 用 户 登 录 失败 后 显示 的 页 面 
register.php 新 用 户 用 来 注册 个 人 信息 的 页 面 
regok.php 新 用 户 注册 成 功 后 显示 的 页 面 
regfail.php 新 用 户 注册 失败 后 显示 的 页 面 
lostpassword.php 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
showquestion.php 查询 密码 时 输入 提示 问题 的 页 面 
showpassword.php 答对 查询 密码 问题 后 显示 的 页 面 
userupdate.php 修改 用 户 资料 的 页 面 
userupdateok.php 成 功 更 新 用 户 资料 后 显示 的 页 面 
logout.php 退出 用 户 系统 的 页 面 





4.1.2 ”搭建 系统 数据 库 


通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 以 及 一 
些 个 人 信息 ， 如 性 别 、 年 龄 、E-mail、 电 话 等， 所 以 在 数据 库 中 必须 包含 一 个 容纳 上 述 信息 的 表 ， 
称 之 为 “用 户 信息 表 ”， 将 数据 库 命 名 为 member。 搭 建 数据 库 和 数据 表 的 步骤 如 下 : 

步 又 014 在 phpMyAdmin 中 建立 数据 库 member， 单 击 选择 避 数据 库 命令 ， 打 开本 地 的 “数据 
库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 member， 单 击 打 开 后 面 的 数据 库 类 
型 下 拉 按 钮 ， 在 弹出 的 下 拉 列 表 框 中 选择 “utf8_general ci” 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返 回 “ 常 
规 设置 ”页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 member 的 数据 库 ， 如 图 4-1 所 示 。 
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phpMyAdmin 
Po 了 到 据 诛 月 SaL 重 革 赤 有 5 用 P 户 司 Ss 己 SA vs 
过 其 访问 过 由 巷 夫 





lL_my nicode (六 丙 训 不 大 二 


ee 日 

图 41 创建 member 数据 库 

步骤 024 单 击 左边 的 member 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 输 入 数据 表 名 

member， 在 “字段 数 ”文本 框 中 输入 本 数据 表 的 字段 数 为 12， 表 示 将 创建 12 个 字段 来 存储 数据 ， 

再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ,输入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 4-2 所 示 。 
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2 碳 友 BO MD sR 
3 日 0 三 时 国电“ 时 区 
4 再 天 于 辣 胃 # 疙 入 面 了 -到 
S 二 外 
下 否 毛 rs 
7 EE EE TL 
a st BO Me ER 
ol EY 四 户 三省 国 让 一 ~ 理 
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图 4-2 建立 member 数据 表 
各 字段 如 表 4-2 所 示 ， 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 及 登入 的 
账号 与 密码 。 
表 4-2 member 数据 表 


字段 名 称 字段 类 型 字段 大 小 说 明 
D |im |hu | 用 户 编号 


username 用 户 账号 
password 用 户 密码 


question Varchar 50 找 回 密码 提示 
answer Varchar 50 答案 
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( 续 表 ) 
字段 名 称 字段 类 型 字段 大 小 说 明 
truename Varchar 50 真实 姓名 
SeX 性 别 
address 地 址 
tel 电话 
QQ QQ 号 码 
email | Varchar 50 | 邮箱 
authority | char 1 | 登录 者 身份 区 分 








创建 的 数据 表 有 12 个 字段 ， 读 者 在 开发 其 他 用 户 管理 系统 时 可 以 根据 采集 用 户 信 息 的 需要 加 
入 更 多 的 字段 。 


4.1.3 用 户 管理 系统 站 点 


在 Dreamweaver CC 2017 中 创建 一 个 “用 户 管理 系统 ”网 站 站 点 member， 由 于 这 是 PHP 数 据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-3 所 示 。 





表 4-3 ”站 点 设置 的 基本 参数 


创建 member 站 点 的 具体 操作 步骤 如 下 : 


步骤 014 首先 在 D:\xampp\htdocs 路 径 下 建立 member 文 件 夹 ( 如 图 4-3 所 示 ) ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 
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4-3 ”建立 站 点 文件 夹 member 
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步 又 024 运行 Dreamweaver CC 2017， 


执行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 
“管理 站 点 ”对 话 框 ， 如 图 4-4 所 示 。 


























图 44 “管理 站 点 ”对 话 框 
步骤 034 对话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 面 的 “新 
建站 点 ”按钮 打开 “站 点 设置 对 象 ” 对 话 框 ， 进 行 如 图 4-5 所 示 的 参数 设置 。 


7 
Le 
pe 
C55 天 处 理 器 及 可 在 其 中 将 相同 文件 宪 布 到 Web 上 的 栅 务 中 上 的 ; i 


全 可 以 在 由 为 Dreammesver 站 志和 玉 寺 六 件 天 和 各 部 


专 地 法 疝 多 件 大: Orvarep Peecr Penbe 


Cw ) ( 


mm ) 








图 4-5 建立 member 站 点 


步骤 044 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [EE， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 4-6 所 示 的 参数 设置 。 





i x 
的 E:3 E73 
Ee BS nerber 
Sia 
连接 方法 : 本 地 /和 | 


玫 和 冲天 :Diyenppjicec 马 


womunt: Moz on nembel |] 


二 而 








Cw) CEj 〇 Cw ) | 诗 


图 4-6 “基本 ”选项 卡 设置 
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步骤 05 人 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信 息 ” 复 选 框 , 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL (表示 是 使 用 PHP 开 发 的 网 页 ) ， 
其 他 的 保持 默认 值 ， 如 图 4-7 所 示 。 





让 高 设置 对 象 member 
se| = 
C5 运程 服务 器 
高 总 设 轩 加 稚 护 局 步 信息 
口 保 丰 对 自动 将 文件 上 传 到 服务 器 
口 启用 文件 取出 功能 
取出 名 称 : 
电子 邮件 地 址 : 
测 j 服 务 器 
| 
编辑 服 
加 持 文件 自动 推 运 到 到 试 职 务 器 
口 类 经 自动 保存 相关 文件 
击 ) Se 





图 4-7 设置 “高 级 ”选项 卡 
步 最 064 单 击 “ 保 存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 单 选 按钮 ， 如 图 4-8 
所 示 。 





[ER 全 村 在 化 人 本 汉人 web 上 的 四 了 的 了 和 吕 。 此 计 话 的 让 

pi lnternet 服务 提供 商 (1SP) 或 Web 管理 只。 

2 Ei 地 址 连接 运程。 测 式 
+- SHE 


保存 时 自动 推送 
放大 他 本， 更 了 文人 的 折 动 恰 关 ， 调 日 了 
秀 刀 论 畦 并 避 消 寺中“ 划 坝 "这 大 卡 中 的 自动 推 半 法 而 * 





Cm Cw Cw ) 
图 4-8 设置 “服务 器 ”参数 
步骤 074 单 击 “保存 ”按钮 ， 即 可 完成 站 点 的 定义 设置 ， 在 Dreamweaver CC 2017 中 就 已 经 
拥有 了 刚才 所 设置 的 站 点 member。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CC 2017 测 试用 户 管 理 系统 网 页 的 网 站 环境 设置 。 





4.1.4 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 的 连接 
设置 如 下 : 
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步 又 014 将 本 实例 的 静态 文件 复制 到 站 点 文件 天 下 ， 打 开 conn.php， 如 图 4-9 所 示 。 











图 4-9 打开 conn.php 网 页 
步骤 024 打开 该 文件 并 使 用 “代码 ”视图 ， 输 入 MySQL 的 连接 代码 ， 如 图 4-10 所 示 。 


Dw xm wen) m6 二 Im mn dam OW mene sa. or Le 
Nh 三 机 - 
er- 











CC 避 此 3 个 字 人 
~ ou Sa = 


图 4-10 数据 库 连接 设置 
在 这 个 文件 中 定义 了 与 MySQL 服 务 器 的 连接 (mysqli_connect 函 数 ) ， 包 括 以 下 内 容 。 


<?php 
// 建 立 数 据 库 连 接 ， 连 接 到 member 数 据 库 ; 
$conn=mysqli_connect ("localhost", "root","","member"); 
// 设 置 字符 为 btE-8，@ 抑 制 字符 变量 的 声明 提醒 。 
@ mysqli_set_charset ($conn,utf8); 
@ mysqli query($conn,utf8); 
// 如 果 连 接 错误 显示 错误 原因 。 
if (mysqli_connect_errno (S$conn) ) 
{ 
echo "连接 MySQL 失败 : " . mysqli connect error(); 
} 
?> 


连接 后 才能 对 数据 库 进行 查询 、 新 增 、 修 改 或 删除 的 操作 。 如 果 在 网 站 制作 完成 后 将 文件 上 
传 至 网 络 上 的 主机 空间 时 发 现 ， 网 络 上 的 MySQL 服 务 器 访问 的 用 户 名 、 密 码 等 方面 与 本 机 设置 有 
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所 不 同 ， 可 以 直接 修改 conn.php 文 件 。 


本 本 用 户 登录 功能 


本 节 主 要 介绍 用 户 登 录 功能 的 制作 ， 用 户 管理 系统 的 第 一 个 功能 就 是 要 提供 一 个 所 有 会 员 进 
行 登录 的 窗口 。 


4.2.1 设计 登录 页 面 


当 用 户 访问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登 录 页 面 来 实现 的 。 所 
以 登录 页 面 中 必须 有 要 求 用 户 输入 用 户 名 和 密码 的 文本 框 ， 以 及 输入 完成 后 进行 登录 的 “登录 ” 按 
钮 和 输入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 署 ” 按 钮 。 


详细 的 制作 步骤 如 下 : 
步 最 014 首先 来 看 一 下 用 户 登录 的 首页 设计 ， 如 图 4-11 所 示 。 


€ oA 127001 [3 
四 as x 国 古 4 


























首 页 用 户 注册 资料 修改 密码 查询 
会 吕 登 录 的 浴 共 
Ee 
几 PS mB 
E23 MB: 
可 a 
守卫 订户 执 E 码 
产品 分 类 
PT 中 区 是 国产 攻打 中 上 一 和 和 欠 村 ， Re 
mr 
beat 加 
[ 要 [ 
BMF BB Van 
有 购物 汽 径 Pp 





图 4-11 用 户 登录 系统 首页 


步 又 024 index.php 页 面 是 用 户 登 录 系统 的 首页 ， 打 开 前 面 创建 的 index.php 页 面 ， 输 入 网 页 
标题 “PHP 用 户 管理 系统 ”， 然 后 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 将 网 页 标题 保存 。 

步骤 034 执行 菜单 栏 “ 文 件 ” 一 “页 面 属 性 ”命令 ， 然 后 在 “背景 颜色 ”文本 框 中 输入 磊 
色 值 为 #CCCCCC， 在 “上 边 距 ” 文 本 框 中 输入 0px， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 个 表格 能 
置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-12 所 示 。 

步骤 044 设置 完成 后 单 击 “ 确 定 ” 按 钮 ， 进 入 “文档 ”窗口 ， 执 行 菜单 栏 “ 插 入 ”一 “ 表 
格 ” 命 令 ， 打 开 “ 表 格 ” 对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 为 3， 在 “ 列 ” 文 
本 框 中 输入 需要 插入 表格 的 列 数 为 3， 在 “表格 宽度 ”文本 框 中 输入 775 像 素 , 设置 “边框 粗细 ” “ 单 
元 格 边 距 ”和 “单元 格 间距 ”都 为 0， 如 图 4-13 所 示 。 
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Table X 
委 格 大 小 
行 数 : 3 到 3 
委 术 克朗 : 775 。 像素 ~ 
登科 
回 
Jha (css) 国 
本 了 作 (9 日 屿 /字体 EE | 
hy 也 vm ~ 2 三 2 三 
文本 声色 (ry 上 顶部 两 者 
aE (oy | :cccccc 
六 图 本 人 CE) 
生理 (E> we 
Ft 
bm Wo 
Eap: 0 mv TELoF 
CD) CE CD CED| IC ) Cw CED 
图 4-12 “页 面 属性 ”对 话 框 


图 4-13 设置 “表格 ”属性 

步骤 054 单 击 “确定 ”按钮 ， 这 样 就 在 “文档 ”窗口 中 插入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 
旨 针 放置 在 第 1 行 表格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 国 |， 将 
第 1 行 表格 合 并 ， 再 执行 菜单 栏 “ 插 入 ”一 “图 像 ”命令 ， 打 开 “ 选 择 图 像 源 文件 ”对 话 框 ， 在 站 
点 images 文 件 夹 中 选择 图 片 01.gif， 如 图 4-14 所 示 。 








国 远 和 回避 天 文件 和 
€ ~ 个 国 < htdocs ; member ，images Y 书香 穴 "images” 万 
组 织 ” 新建 文件 突 © 

局 cresive coudfr 天 下 
re 
人 OneDive 到 
加 此 思科 -| 三 
图 视 源 D2.gif 02 01.gif 02 02.gif 
EL = a 
目 闻 9 与 
及 本 DD 国 
本 语 | 
国 点 本 04gif 05.gif gif 
各 本 地 区 盘 (C) 
一 本 地 EE 羡 (D 
Ba 于: [四 加 
文件 名 IN [01.gif “| [国文 件 Cgif-jpgrjpegrp ~ 
EE 廿 





图 4-14 “选择 图 像 源 文件 ”对 话 框 
步骤 064 单 击 “ 确 定 ”按钮 ， 即 可 在 表格 中 插入 此 图 片 。 将 鼠标 指针 放置 在 第 3 行 表格 中 ， 
在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ” 按 旬 [加 |， 将 第 3 行 所 有 单元 格 合并 ， 再 执行 
菜单 栏 “ 插 入 ”一 “图 像 ”命令 ， 打 开 “ 选 择 图 像 源 文件 ”对 话 框 ， 在 站 点 images 文 件 夹 中 选择 图 
片 05.gif， 插 入 一 个 图 片 ， 效 果 如 图 4-15 所 示 。 
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图 4-15 插入 图 片 效果 图 


步骤 D7 和 插入 图 片 后 ， 选 择 插入 的 整个 表格 ， 在 “属性 ”面板 的 “对 齐 ” 下 拉 列 表 框 中 选 
择 “ 居 中 对 齐 ” 选 项 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-16 所 示 。 





步 又 08 4 把 光标 移 至 创建 的 表格 第 2 行 第 1 列 中 ， 在 “属性 ”面板 中 设置 高 度 为 456 像 素 、 宽 
度 为 179 像 素 , 设置 高 度 和 宽度 根据 背景 图 像 而 定 , 从 “背景 " 中 选择 该 站 点 images 文 件 天 中 的 02.gif 
文件 ， 得 到 如 图 4-17 所 示 的 效果 。 


夯 camppwmtdocewmembewindexphp” a 
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图 4-17 插入 图 片 的 效果 图 


步 野 094 在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插入 同 站 点 images 文 件 夹 中 的 图 片 03.gif 和 
04.gif， 完 成 网 页 的 结构 搭建 ， 如 图 4-18 所 示 。 
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图 4-18 完成 的 网 页 背景 效果 图 


步骤 104 单 击 第 2 行 第 1 列 单 元 格 ， 然 后 单 击 “ 文 档 ” 窗 口上 的 国 激 女 四 深 钮 ， 在 <td 和 /td> 之 
间 加 入 valign="top" (表格 文字 和 图 片 的 相对 摆 放 位 置 ， 可 选 值 有 top、middle、bottom ) 的 命令 ， 


表示 让 和 鼠标 指针 能 够 自动 地 贴 至 该 单元 格 的 最 顶部 ， 设 置 如 图 4-19 所 示 。 
Dw 六 FF mi) mv mA 工 BT 本 MD Mels) gOW web Fe or 辐 














YB, 


文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 


分 ”和 “设计 ”视图 ) 、 


步骤 114 单 击 “ 文 档 ” 


建 的 表格 的 单元 格 中 ， 执 行 菜单 栏 “ 插 入 ”一 


个 表单 。 
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它们 提供 各 种 文档 
各 种 查看 选项 和 一 些 常用 操作 ( 如 在 浏览 器 中 预览 ) 。 


“窗口 视图 ” (如 “代码 ” 


窗口 上 的 [设计 | 按钮 ， 返 回 文档 窗口 的 “设计 ”窗口 模式 ， 在 刚 创 
“表单 ”一 “表单 ”命令 ( 如 图 4-20 所 示 ) ， 插 入 一 
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图 4-20 执行 “表单 ”命令 

步 又 124 将 筷 标 指针 放置 在 该 表单 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 
对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 $， 在 “ 列 ” 文 本 框 中 输入 2。 在 “表格 宽度 ”文本 框 中 输入 179 
像素 ， 在 该 表单 中 插入 5 行 2 列 的 表格 。 单 击 并 拖 动 鼠 标 分 别 选 择 第 1 行 、 第 2 行 和 第 5 行 表格 ， 并 分 
别 在 “属性 ”面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 回 ， 将 这 几 行 表格 进行 合并 。 
然后 在 表格 的 第 1 行 输入 “会 员 登 录 ” 四 个 字 ， 在 第 2 行 第 1 列 中 输入 文字 说 明 “ 用 户 名 ”， 在 第 2 
行 第 2 列 中 执行 菜单 栏 “ 插 入 ”一 “表单 ”一 “文本 ”命令 ， 插 入 一 个 单行 文本 域 表单 对 象 ， 并 定 
义 文本 域名 为 “username” ，“ 文 本 域 ”属性 设置 如 图 4-21 所 示 。 





文本 域 字符 度 (WD) 12 类 型 回音 和 6) ” 〇 行 虽 。 〇 密 f) 。 类 (0) 无。 ”~ 
[osernone_ 最 多 字符 数 ， 初 好 值 D 多 














图 4-21 “文本 域 ”的 设置 


设置 文本 域 的 属性 说 明 如 下 : 

@ 文本 域 : 在 “文本 域 ” 文 本 框 中 为 文本 域 指定 一 个 名 称 ， 每 个 文本 域 都 必须 有 一 个 唯一 名 
称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 。 可 以 使 用 字母 、 数 字 、 字 符 和 下 画 线 (_) 
的 任意 组 合 。 请 注意 ， 为 文本 域 指定 的 标签 是 存储 该 域 的 值 (输入 的 数据 ) 的 变量 名 ， 这 
是 发 送 给 服务 器 进行 处 理 的 值 。 

@ 字符 宽度 : “字符 宽度 ”设置 域 中 最 多 可 显示 的 字符 数 。“ 最 多 字符 数 ”指定 在 域 中 最 多 
可 输入 的 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。 “字符 宽度 ”可 以 小 于 “最 多 字符 
数 ”， 但 大 于 字符 宽度 的 输入 则 不 被 显示 。 

@ ”初始 值 ' “初始 值 ” 指 定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 
值 ， 可 以 指示 用 户 在 域 中 输入 信息 。 

@ 类 : “类 ”可 以 将 CSS 规 则 应 用 于 对 象 。 


步骤 134 在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “密码 ”， 在 第 3 行 表格 的 第 2 列 中 执行 菜单 栏 
“插入 ”一 “表单 ”一 “文本 ”命令 ， 插 入 密码 文本 域 表单 对 象 ， 定 义 “文本 域 ” 名 为 password。 
“文本 域 ” 属 性 设置 及 此 时 的 效果 分 别 如 图 4-22 和 图 4-23 所 示 。 
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回 文本 域 字符 训 度 0) 12 类型 单行 6) 。 口 多 行 四 加 害 3(P) 。 类 (0) | 无 ~ 

essvord 最 多 字符 数 。 | 初 权 值 () 7 
口头) 
DORR l : 
图 422 密码 “文本 域 ” 的 设置 图 423 密码 “文本 域 ”效果 


步骤 14 人 和 选择 第 4 行 单元 格 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ”一 “按钮 ”命令 两 次 ， 插 入 两 
个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 一 个 为 “ 重 
设 表 单 ” 选 项 ，“ 属 性 ”的 设置 分 别 如 图 4-24 和 图 4-25 所 示 。 





找 钮 名称 值 () 可 录 动作 加 提交 表单 (s) 口 无 人 类 @) [无 ~] 
amit | 加重 设 表单 (E) 





图 4-24 设置 按钮 名 称 








按钮 名 称 值 (mW 重 秆 _ 动作 口 提交 表单 G) 口 无 叫 类 (C)| 无 ~ 











Eumitz | 加 重 设 表单 (R) 





图 4-25 设置 按钮 名 称 2 


步 又 154 在 第 5 行 输入 “注册 新 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 register.php 的 链 
接 对 象 ， 以 方便 用 户 注册 ， 如 图 4-26 所 示 。 

















加 

HL 格 开 (5) 无 ~ 类 ( 殉 DBJ 汪 申 符 举 权 m © 

如 css DD 无 ~ 狼 红 (9 registerphp ~@ 白 。 上 (6) ~ 4 

EE ~ (Ww) 招行 (0) 口 。 背 景 志 (6) 全 (页 而 属性 .| 

ee 门 订 要 二 m 由 人 ~ 高 ml 22 本 回 口 训 
图 4-26 建立 链接 


步骤 164 如 果 已 经 注册 的 用 户 忘记 了 密码 ， 还 希望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 查询 页 面 lostpassword.php 的 链接 对 象 ， 
方便 用 户 取 回 密码 ， 如 图 4-27 所 示 。 








豆 
Hm 格 #t(F) 无 Sy 类 (无 BJ 兴旺 上 生 二 机 0 @ 
妈 css JD 元 ~ 甸 接 们 lostpasswordphp ~ 名 白 。 上 (9) > 四 
到。 单元 格 水 平 四 ”骂人 ~ NW 7 知行 (o) 口 背景 颜色 (c) [J (而 属性 - | 
ED 











让 要 直人 由 人 ~ 高 2 本 名 口 
图 4-27 密码 查询 设置 
步骤 17A 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 使 用 户 可 以 通过 该 网 页 中 表单 
的 提交 实现 登录 功能 。 表单 对 象 对 应 的 “属性 ”面板 的 “动作 ”属性 值 为 “chkuser.php”， 方法 为 
“POST”， 如 图 4-28 所 示 。 它 的 作用 就 是 实现 表单 跳 转 的 功能 。 
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动作 [sheser php 局 目标 () ~ 元 过 
方法 |PosT ~ 编码 类 型 ~ 















































图 4-28 表单 对 应 的 “属性 ”面板 


步骤 184 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 
首页 制作 。 


步骤 19 表单 提交 到 chkuser.php 动 态 网 页 进行 验证 ， 如 果 登 录用 户 名 和 密码 都 正确 就 跳 转 
到 welcome.php; 如 果 登 录 失败 提示 登录 失败 原因 ， 具 体 实 现 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$username=$_POST['username']; 
$userpwd=$_POST['password']; 
class chkinput{ 
Var $name; 
Var $pwd; 
function chkinput ($x, $y){ 
$this->name=$x; 
$this->pwd=$y; 
} 
function checkinput(){ 
include ("conn.php"); 
// 判 断 名 称 和 密码 是 否 正确 
$sql=mysqli query($conn,"select * from member where username= '".$this-> 
name."'"); 
$info=mysqli_ fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 不 存在 此 用 户 ! ');history. 
back() ;</script>"; 
exit; 
1 
else{ 
if($info['authority']==1){ 
echo "<script language='javascript'>alert(' 该 用 户 已 经 被 冻结 ! 
') ;history.back();</script>"; 
exit; 
} 
if($info['password']==$this->pwd) 
{ 
session start(); 
$_SESSION['username']=$info['username']; 
$_SESSION['ID']=$info['ID']; 
header ("location:welcome.php"); 
// 设 置 阶段 变量 转向 至 welcome .php 页 面 
exit; 
} 
else 
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echo "<script language='javascript'>alert(' 密码 输入 错误 ! '); 
</script>"; 
header ("location: loginfail .php"); 
// 登 录 失败 跳 转 至 loginfail .php 页 面 
exit; 
| 
由 
} 
S$obj=new chkinput (trim($username) ,trim($userpwd)); 
$obj->checkinput (); 
es 


4.2.2 ”登录 成 功 和 失败 

当 用 户 输入 的 登录 信息 不 正确 时 ， 就 会 转 到 loginfail.php 页 面 ， 显 示 登 录 失 败 的 信息 。 如 果 用 
户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome.php 页 面 。 

步 又 014 执行 菜单 栏 “文件” 一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 loginfail.php 
的 网 页 并 保存 。 

步骤 024 登录 失败 的 页 面 设计 如 图 4-29 所 示 。 在 “文档 ”窗口 中 选中 “这 里 ”文本 ， 在 其 
对 应 的 “属性 ”面板 上 的 “链接 ”文本 框 中 输入 index.php， 将 其 设置 为 指向 index.php 页 面 的 链接 。 


DW xan a a An IRT to) sey gO we a a 






bss 24 a 闻 
用 户 寻 菏 用 户 法 骨 资料 作 改 密 三 查询 








Fr Pe 
Fr” 用 
om a dar 
Pe 
sme oo 
JE 得 
pm 四 
中 而 
GD = 
Es 天 a 
mm ean on. 





图 4-29 ”登录 失败 页 面 loginfail.php 
步骤 03 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 完 成 loginfail.php 页 面 的 创建 。 
制作 welcome.php 页 面 ， 详 细 制 作 的 步骤 如 下 : 
步 又 014 执行 菜单 栏 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 welcome.php 
的 网 页 并 保存 。 
步 又 024 用 类 似 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4.30 所 示 。 
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图 4-30 欢迎 界面 的 效果 图 


下 面 使 用 阶段 变量 实现 登录 成 功 后 显示 用 户 名 ， 阶 段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 象 ， 
用 户 信 息 得 以 存储 , 并 使 该 信息 在 用 户 访问 的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶段 变量 还 
可 以 提供 一 种 超时 形式 的 安全 对 象 , 这 种 对 象 在 用 户 账户 长 时 间 不 活动 的 情况 下 , 终止 该 用 户 的 会 
话 。 如 果 用 户 忘 记 从 Web 站 点 注销 ， 这 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资源 。 在 网 页 中 加 入 PHP 
调用 阶段 变量 的 代码 如 下 : 
<?php 
$ID=@ $_SESSION[ID]; 
if(@ $_SESSION['username']!="''){ 


echo "用 户 :$_SESSION [username] 欢 迎 您 "; 
} 


效果 如 图 4-31 所 示 ， 这 样 就 完成 了 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 


SD 
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图 4-31 插入 后 的 效果 
步骤 034 在 “文档 ”窗口 中 拖 动 鼠标 选中 “注销 你 的 用 户 ” 文 本 。 在 “注销 你 的 用 户 ” 链 
接 文本 对 应 的 “属性 ”面板 中 将 “链接 ”属性 值 设 为 logoutphp， 如 图 4-32 所 示 。 

















必 住 = 
FL 格式 加 无 ~ 类 (无 小 BJ 六 时 生生 本 中 @ 
FA mm 元 > 人 logoutphp ~ 名 白 。 杂 ( -7 虹 
到 音 格 “水平 凤 是 人 ~ WwW) 7 向 行 (o) 口 背景 颜色 (c) 全 | (页 面 属性 -。 
加 一半 委 直 (m 点 人 ~ ”高 H) 2w 本 田口 


四 


图 4-32 属性 面板 设置 


步 邓 04 和、logout.php 的 页 面 设计 比较 简单 ， 不 作 详 细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index.php 就 可 以 了 ， 效 果 如 图 4-33 所 示 。 
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图 4-33 注销 用 户 页 面 设计 效果 图 
步骤 054 退出 登录 的 PHP 命 令 很 简单 ， 如 下 所 示 : 
<?php 
session start (); 
session destroy(); 


// 清 空 阶段 变量 ， 退 出 用 户 登 录 


> 


步 最 064 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 编 辑 工作 完 
成 后 ， 就 可 以 测试 该 用 户 登 录 系统 的 执行 情况 了 。 文档 中 的 “修改 你 的 资料 ”链接 到 userupdate.php 


页 面 ， 此 页 面 将 在 后 面 的 小 节 中 进行 介绍 。 


4.2.3 测试 登录 功能 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 使 有 用。 下面 就 对 登录 系统 进行 测试 ， 


测试 的 步骤 如 下 : 


4-34 所 示 。 
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图 4-34 打开 的 网 站 首页 


按钮 。 
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步骤 01 打开 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/member/， 打 开 index.php 页 面 ， 如 图 


步 野 024 在“ 用户 名 ”和 “密码 ”文本 框 中 输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 录 ” 


步骤 034 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 浏 览 器 就 会 转 到 





2 < 可 ~ 六 
首 页 用 户 登录 用 户 注册 资料 修改 密码 查询 
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Er 
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图 435 登录 失败 页 面 loginfail.php 效果 
步骤 044 如 果 输入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 登 录 成 功 后 的 页 面 如 图 
4-36 所 示 ， 其 中 显示 了 用 户 名 admin。 
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图 4-36 ”登录 成 功 页 面 welcome.php 效果 


步 肾 05 人 和 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链接 即 可 ， 注 销 用 户 后 ， 浏 览 
器 就 会 转 到 页 面 logoutphp， 然 后 单 击 “这 里 ” 回 到 首页 ， 如 图 4-37 所 示 。 至 此 ， 登 录 功 能 就 测试 
完成 了 。 
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图 4-37 注销 用 户 页 面 


概要 时 用 户 注册 功能 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 为 新 用 户 
注册 用 的 页 面 ， 对 于 新 用 户 来 说 ， 通 过 单 击 index.php 页 面 上 的 “用 户 注册 ” 超 链接 ， 进 入 到 名 为 
register.php 的 页 面 ， 在 该 页 面 可 以 实现 新 用 户 的 注册 功能 。 


4.3.1 用 户 注册 页 面 


register.php 页 面 主要 是 实现 用 户 注册 的 功能 ， 用 户 注册 的 操作 就 是 向 数据 库 的 member 表 中 添 
加 记录 的 操作 ， 完 成 的 页 面 如 图 4-38 所 示 。 


DW xsln ma Es WA IAM WD) ws( WOW Wh Pe 9 (~ 
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图 4-38 ”用 户 注 册页 面 样式 


步骤 01 人 执行 菜单 栏 “文件 ”一 “新建” 命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 register.php 
的 网 页 并 保存 。 


步骤 02 和 在 Dreamweaver 中 ,使 用 制作 静态 网 页 的 工具 完成 如 图 4-39 所 示 的 静态 部 分 。 这 里 
要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ”并 命名 为 authority， 设 置 默 认 值 为 0， 即 所 有 的 用 户 
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图 4-39 registerphp 页 面 静态 设计 


LE 

在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 member 表 中 ， 可 以 
将 表单 对 象 中 的 文本 域名 设置 得 与 数据 库 中 的 相应 字段 名 相同 ,这 样 做 的 目的 是 当 该 表单 中 的 
内 容 添加 到 member 表 中 时 会 自动 配对 ， 文 本 “重复 密码 ”对 应 的 文本 框 命名 为 password1。 隐 
藏 域 是 用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 说 ， 隐 藏 域 是 看 不 见 的 。 当 表 
单 被 提交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 到 服务 器 上 。 


步骤 034 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 否 满足 
数据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 填写 的 注册 资料 提交 到 服务 器 之 前 ， 就 会 对 用 户 填写 
的 资料 进行 验证 , 如 果 有 不 符合 要 求 的 信息 , 可 以 向 访问 者 显示 错误 的 原因 , 并 让 访问 者 重新 输入 。 
在 表单 提交 时 加 入 一 个 onSubmit="return chkinput(this)" 命 令 ， 在 body 前 面 加 入 表单 验证 的 JavaScript 
代码 ， 该 验证 基本 包括 了 目前 所 有 表单 的 验证 功能 ， 包 括 不 能 空 、 密 码 重 复 验证 、 邮 箱 验 证 等 ， 具 
体 的 代码 如 下 : 


<script language="javascript"> 
function chkinput (form) 
{ 
if(form.username.value=="") 
{ 
alert ("请 输入 昵称 !"); 
form.username.select (); 
return (false); 
} 
if (form.password.value=="") 
{ 
alert ("请 输入 注册 密码 !") ; 
form.password.select (); 
return (false); 
1 
if(form.passwordl1 .value=="") 
{ 
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if(form.address.value=="") 
{ 
alert ("请 输入 家 庭 住址 !"); 
form.address.select (); 
return (false); 
’ 
if(form.question.value=="" 
{ 
alert ("请 选择 密码 提示 答案 !") ; 
form.question.select (); 
return (false); 
’ 
if(form.answer.value=="" 
{ 
alert ("请 输 密 码 提示 答案 !"); 
form.answer.select (); 
return (false); 
L 
return (true); 
F 
</script> 


本 例 中 ， 用 户 名 是 用 户 登录 的 身份 标志 ， 用 户 名 是 不 能 够 重复 的 ， 所 以 在 添加 记录 之 前 ， 一 
定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 存在 ， 如 果 存 在 ， 则 不 能 进行 注册 。 同 时 我 们 设置 usermame 
文本 域 、password 文 本 域 、password1 文 本 域 、answer 文 本 域 、truename 文 本 域 、address 文 本 域 为 “ 值 : 
必需 的 ”“ 可 接受 : 任何 东西 ”， 即 这 几 个 文本 域 必 须 填 写 ， 内 容 不 限 ， 但 不 能 为 空 ; tel 文 本 域 和 
QQ 文本 域 设置 的 验证 条 件 为 “ 值 : 必需 的 ”“ 可 接受 : 数字 ”， 表 示 这 2 个 文本 域 必 须 填写 数字 ， 
不 能 为 空 ，Email 文 本 域 的 验证 条 件 为 “ 值 ， 必 需 的 ”“ 可 接受 ， 电子 邮件 地 址 ”， 表 示 该 文本 域 
必须 填写 电子 邮件 地 址 ， 且 不 能 为 空 。 

步骤 044 完成 对 检查 表单 的 验证 设置 之 后 ， 将 <form> 表 单 提交 到 regok.php 网 页 进行 进一步 
的 验证 并 写 入 MySQL 数 据 库 。 代 码 如 下 : 


<form action="regok.php" method="POST" name="forml" onSubmit="return 
chkinput (this)"> 


4.3.2 ”注册 成 功 和 失败 


为 了 方便 用 户 登录 ， 应 该 在 regok.php 页 面 中 设置 一 个 转 到 index.php 页 面 的 文字 链接 ， 以 方便 
用 户 进行 登录 。 同 时 ， 为 了 方便 访问 者 重新 进行 注册 ， 则 应 该 在 regfail.php 页 面 设置 一 个 转 到 
register.php 页 面 的 文字 链接 ， 以 方便 用 户 进行 重新 注册 。 本 小 节制 作 显示 注册 成 功 和 失败 的 页 面 信 
息 。 

步 最 014 执行 菜单 栏 “ 文 件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 regok.php 的 
网 页 并 保存 。 


步骤 024 regok.php 页 面 如 图 4-40 所 示 。 制 作 比 较 简单 ， 其 中 将 文本 “这 里 ”设置 为 指向 
index.php 页 面 的 链接 。 
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4-40 注册 成 功 regok.php 页 面 


步骤 034 表单 的 数据 提交 到 regok.php 网 页 时 需要 将 数据 先 插入 到 数据 库 ， 使 用 PHP 的 insert 
into 语 句 实现， 具体 的 代码 如 下 : 


<?php 
include ("conn.php"); 
$username=$_POST['username']; 
$sqll=mysqli_ query ($conn,"select * from member where username='".$username."'"); 
$infol=mysqli fetch array($sql1); 
if ($infol==true) 
| 
echo "对 不 起 , 该 昵称 已 被 占用 !"; 
header ("location: regfail.php"); 
} 
else 
{ 
/ /接收 表 单 变量 


$username=$_POST['username']; 
$password=$_POST['password']; 
$question=$_POST['question']; 
$answer=$_POST['answer']; 
$truename=$_POST['truename']; 
$sex=$_POST['sex']; 
$address=$_POST['address']; 
$tel=$_POST['tel']; 
$QQ=$_POST['QQ']; 
$email=$_POST['email']; 
$authority=0; 
// 设 置 字段 名 称 并 对 应 插入 数据 库 
mysqli_ query($conn,"insert into member (username,password,question,answer, 
truename, sex,address, tel,QQ,email,authority) values ('$username','$password', 
'$question','$answer','$truename','$sex','$address','$tel','$QQ0','$email','$au 
thority')"); 
ke 


再 执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 本 页 的 制作 。 
步 最 044 如 果 用 户 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 向 用 户 显示 注册 失败 
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的 信息 。 这 里 再 新 建 一 个 regfail.php 页 面 ， 该 页 面 的 设计 如 图 4-41 所 示 。 其 中 将 文本 “这 里 ”设置 
为 指向 register.php 页 面 的 链接 。 





DW Zen sn ss HM TEM so) Se eC wm .0 (IST™ 








图 4-41 注册 失败 regfail.php 页 面 


4.3.3 ”注册 功能 的 测试 
设计 完成 后 ， 就 可 以 测试 该 用 户 注册 功能 的 执行 情况 。 
步 又 014 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/register.php， 打 开 register.php 
文件 ， 如 图 4-42 所 示 。 


EE 
€ 人 OO 信 |@ 127001 


8 
用 户 登录 用 户 注册 资料 修改 
ET 
用 户 和 








起 好: 
Ee EL 
ET 


国 四 





图 4-42 打开 的 测试 页 面 
步骤 024 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 用 户 名 、 密 码 等 必 填 字 段 ， 
或 填写 非法 的 E-mail 地 址 ， 或 在 确认 密码 时 两 次 输入 的 密码 不 一 致 ， 以 测试 网 页 中 验证 表单 动作 的 
执行 情况 。 如 果 填 写 的 信息 不 正确 ， 则 浏览 器 应 该 打开 提示 信息 框 ,向 访问 者 显示 错误 原因 ， 如 图 
4-43 所 示 是 一 个 提示 信息 框 示例 。 
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E30Fem A 
CHO 127.0.01/member/registe 


DR 


应 wi a 
”用户 登录 用 户 注册 资料 修改 密码 查询 


127.0.01 上 9 网 页 于 示 : 





图 4-43 出 错 提示 
步骤 034 在 该 注册 页 面 中 注册 一 个 已 经 存在 的 用 户 名 ， 可 以 输入 design， 用 来 测试 新 用 户 服 
务 器 行为 的 执行 情况 。 然 后 单 击 “ 确 定 ”按钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 器 会 自动 转 到 


regfail.php 页 面 ( 如 图 4-44 所 示 ) ， 告 诉 访问 者 该 用 户 名 已 经 存在 。 此 时 ,访问 者 可 以 单 击 “ 这 里 ” 
链接 文本 ， 返 回 register.php 页 面 ， 以 便 重新 进行 注册 。 


EE 
€|)D)lf | 外 127.0041 


ess _ 222 
用 户 登录 


用 和! 
让 衬 际 


二 单 科 里 新 二 内 1 





图 4-44 ”注册 失败 页 面 显示 
步 最 044 在 该 注册 页 面 中 填写 正确 的 注册 信息 ， 单 击 “确定 ”按钮 。 由 于 这 些 注册 资料 完 
全 正确 ， 而 且 这 个 用 户 名 没有 重复 ， 浏 览 器 会 转 到 regok.php 页 面 ， 向 访问 者 显示 注册 成 功 的 信息 ， 
如 图 4-45 所 示 。 此 时 ,访问 者 可 以 单 击 “这 里 ”链接 文本 ， 转 到 index.php 页 面 ， 以 便 进 行 登录 。 
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EE 
所 二 妆 | 娘 | 四 127.001/ mmbe/ 














请 南庄 未 ! 





图 4-45 注册 成 功 页 面 
在 MySQL 中 打开 用 户 数 据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 以 看 到 ， 
在 该 表 的 最 后 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚才 在 网 页 register.php 中 提交 的 注册 用 户 的 信 
息 ， 如 图 4-46 所 示 。 
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图 4-46 向 member 表 中 添加 了 一 条 新 记录 

至 此 ， 基 本 完成 了 用 户 管理 系统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根据 制作 
网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 , 也 可 以 给 需要 注册 的 文本 域名 称 部 分 添加 星 号 (*) ， 
提醒 用 户 注 册 时 注意 。 


二 到 修改 用 户 资料 


修改 注册 用 户 资料 的 过 程 就 是 使 用 户 数 据 表 更 新 记录 的 过 程 ， 本 节 重 点 介绍 如 何在 用 户 管理 
系统 中 实现 用 户 资料 的 修改 功能 。 
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4.4.1 修改 资料 页 面 


该 页 面 主要 把 用 户 所 有 资料 都 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 具 体 的 制 
作 步 又 如 下 : 


步骤 014 修改 资料 的 页 面 和 用 户 注册 页 面 的 结构 十 分 相似 , 可 以 通过 对 register.php 页 面 的 修 
改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 register.php 页 面 ， 执 行 菜单 栏 “ 文 件 ” 一 “另存 为 ” 命 
令 ， 将 该 文档 另存 为 userupdate.php， 并 在 第 一 行 加 入 如 下 代码 : 
<?php 


session start(); 
全 


// 启动 session 环 境 

步骤 024 执行 菜单 栏 “ 窗 口 ” 一 “服务 器 行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 在 “ 服 
务 器 行为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文字 ， 该 页 面 修改 完成 后 显示 如 图 4-47 
所 示 。 








图 4-47 userupdate.php 静态 页 面 


步骤 034 需要 根据 传递 过 来 的 用 户 身份 做 一 个 查询 ， 并 将 一 些 已 经 注册 的 信息 绑 定 到 网 页 
的 相关 字段 上 ， 查 询 的 代码 如 下 : 
<?php 
$ID=@ $_GET['ID']; 
$sql=mysqli_query($conn,"select * from member where ID="'$ID'"); 
$info=mysqli fetch array($sql); 
> 


步 又 044 完成 记录 集 字段 绑 定 到 页 面相 应 的 位 置 上 ,注意 插入 一 个 隐藏 域 为 id, 设置 在 用 户 
名 字段 的 后 面 ， 如 图 4-48 所 示 。 其 中 性 别 单 选 按钮 的 查询 绑 定 方法 如 下 : 
/7 判断 传 过 来 的 值 是 男 则 “ 男 ” 单 选 按钮 选中 ， 如 果 是 “ 女 ” 则 女 单 选 按钮 选中 。 


<input type="radio" name="sex" value=" 男 " <?php if ($info['sex']==' 男 ') echo 
"checked" ;?> /> 男 

<input type="radio" name="sex" value=" 女 " <?php if ($info['sex']==' 女 ') echo 
"checked" ;?> /> 女 
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图 4-48 绑 定 动态 内 容 后 的 userupdate.php 页 面 


步骤 054 最 后 将 <form> 表 单 提 交 到 "userupdateok.php 网 页 进行 进一步 的 验证 并 写 入 MySQL 
数据 库 。 代 码 如 下 : 


<form action="userupdateok.php" method="POST" name="forml"> 


4.4.2 ”更 新 成 功 页 面 


用 户 修改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok.php。 具 体 的 制作 步 又 如 下 : 


步骤 01 和 执行 菜单 栏 “ 文 件 ” 一 “新 建 " 命 令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 userupdateok.php 
的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session start(); 
?> 
// 启动 session 环 境 
<?php 
$ID=$_POST['ID']; 
$username=$_POST['username']; 
$password=$_POST['password']; 
$question=$_POST['question']; 
Sanswer=$_POST['answer']; 
$truename=$_POST['truename']; 
$sex=$_POST['sex']; 
$address=$_POST['address']; 
$tel=$_POST['tel']; 
$QQ=$_POST['QQ']; 
$email=$_POST['email']; 
Sauthority=07 
mysqli query($conn, "update member set username=' $username',password= 
'$password',question='$question',truename='$truename',sex='$sex',address='$add 
ress',answer='$answer',tel='$tel',QQ="'$Q0',email='$email',authority="'0' where 
TD=r a PO ED 
2 
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步 又 024 在 该 网 页 中 ， 应 该 向 用 户 显示 资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 
情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 其 提供 一 个 返回 到 userupdate.php 页 面 的 超 文本 链接 ; 如 果 
用 户 不 需要 修改 ， 则 为 其 提供 一 个 转 到 用 户 登 录 页 面 ， 即 index.php 页 面 的 “首页 ” 超 文本 链接 ， 更 
新 成 功 的 页 面 如 图 4-49 所 示 。 


DW zy met so AD IE ED wa ECW Me 








ete 
| mer tp eee i 
| ms me 
| sm oe 
1 > Mmm 
me 和 前 we 
bh Me © mm "a 
总 -之 -全 -了 
A 元 站 (ee BJ/ 每 后 汪汪 人 中 
os 00 tt om 四 
国生 ~ 0 了 MD Rc) 口 人 
站 有 mm 嫩 mo i 到 


图 449 更 新 成 功 的 页 面 
4.4.3 修改 资料 测试 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 ， 测 试 的 步骤 如 下 : 
步 最 014 打开 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/memberindex.php， 打 开 index.php 文 
件 ， 在 该 页 面 中 进行 登录 。 登 录 成 功 后 进入 welcome.php 页 面 ， 在 welcome.php 页 面 单 击 “修改 你 的 
资料 ” 超 链接 ， 转 到 userupdate.php 页 面 ， 如 图 4-50 所 示 。 
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图 4-50 修改 design 用 户 注册 资料 

步 又 024 在 该 页 面 中 进行 一 些 修 改 ， 然 后 单 击 “ 修 改 ” 按 钮 将 修改 结果 发 送 到 服务 器 中 。 
当 用 户 记录 更 新 成 功 后 ， 浏 览 器 会 转 到 userupdateok.php 页 面 中 ， 显 示 修 改 资料 成 功 的 信息 ， 同 时 
还 显示 了 该 用 户 修改 后 的 资料 信息 ,并 提供 转 到 更 新 成 功 页 面 和 转 到 主页 面 的 链接 对 象 ,这 里 对 “ 真 
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实 姓名 ”进行 了 修改 ， 单 击 “ 重 新 修改 ”按钮 转 到 更 新 成 功 页 面 ， 效 果 如 图 4-51 所 示 。 





= EE EE 
| 全 | 站 太 | 加 12700Umenp= Eev 






ES < 
首 页 用 户 悚 录 用 户 注册 资料 修改 宕 码 查询 























图 4-51 更 新 成 功 
上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 制作 成 功 。 


二 本 查询 密码 功能 


通常 会 为 用 户 注册 页 面 设 计 问 题 和 答案 文本 框 ， 它 们 的 作用 是 当 用 户 忘 记 密 码 时 ， 可 以 通过 
这 个 问题 和 答案 到 服务 器 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提供 的 答案 和 数据 库 中 答案 是 
否 相同 ， 如 果 相 同 ， 则 可 以 找 回 遗失 的 密码 。 


4.5.1 查询 密码 页 面 


本 小 节 主 要 制作 密码 查询 页 面 lostpassword.php， 具 体 的 制作 步骤 如 下 : 


步骤 01 人 执行 菜单 栏 “文件 ” ~“ 新 建 " 命令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpassword.php 
的 网 页 并 保存 。 lostpassword.php 页 面 是 用 来 让 用 户 提交 要 查询 遗失 密码 的 用 户 名 的 页 面 , 该 网 页 的 
结构 比较 简单 ， 设 计 后 的 效果 如 图 4-52 所 示 。 
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图 452 lostpassword.php 页 面 
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步 又 024 在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ， 在 “表单 ID” 
文本 框 中 输入 form1， 在 “动作 ”文本 框 中 输入 showquestion.php 作 为 该 表单 提交 的 对 象 页 面 。 在 “ 方 
法 ”下 拉 列 表 框 中 选择 POST 选项 作为 该 表单 的 提交 方式 ， 接 下 来 将 输入 用 户 名 的 文本 域 ， 命 名 为 
username， 分 别 如 图 4-53 和 图 4-54 所 示 。 
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图 4-53 设置 表单 提交 的 动态 属性 
屋 性 
ml 文本 域 字符 宽度 (8) ， 类 型 图 单行 (8) ” 口 多 行 如 。” 口 密 码 (P) ”类 (C) | 无 四 
Jusernane 最 多 字符 数 初始 值 (I) ] 多 
口 禁 用 人 ) 
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图 4-54 设置 用 户 名 文本 域 属性 
其 中 ， 表 单 属性 设置 面板 中 的 主要 选项 作用 如 下 : 


@ 表单 ID: 在 “表单 ID” 文 本 框 中 输入 标识 该 表单 的 唯一 名 称 , 命名 表单 后 就 可 以 使 用 脚本 
语言 引用 或 控制 该 表单 。 如 果 不 命名 表单 , 则 Dreamweaver 使 用 语法 forml、 form2、.….… 
生成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 n 的 值 。 

@ 方法 : 在 “方法 ”下 拉 列 表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。 
> POST: 该 方法 将 在 HTTP 请 求 中 嵌入 表单 数据 。 
> GET: 该 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL 中 ， 是 默认 设置 ， 但 其 缺点 是 表 

单数 据 不 能 太 长 ， 所 以 本 例 选 择 POST 方 法 。 

@ 目标 : “目标 ”下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 。 各 目标 值 含义 如 下 : 

_blank: 在 未 命名 的 新 窗口 中 打开 目标 文档 。 

> _parent: 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 目标 文档 。 

> _self: 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

> _top: 在 当前 窗口 的 窗 体内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 
即使 原始 文档 显示 在 框架 中 。 


用 户 在 lostpassword.php 页 面 中 输入 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 这 时 会 通过 表单 将 用 户 
名 提交 到 showquestion.php 页 面 中 ， 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 对 应 的 提示 问题 
并 显示 在 showquestion.php 页 面 中 ， 使 用 户 可 以 在 该 页 面 中 输入 问题 的 答案 。 下 面 就 制作 显示 问题 
的 页 面 。 


v 


步骤 034 新 建 一 个 文档 . 设置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ”， 执 行 菜单 栏 “ 文 
件 ” 一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion.php。 


步骤 044 在 Dreamweaver CC 2017 中 制作 静态 网 页 ， 完 成 的 效果 如 图 4-55 所 示 。 


142 


第 4 章 ”全程 实 例 二 : 用 户 管理 系统 





[7 三 人 ISTE 
而 本 醒 - 





4-55 ”showquestion.php 静态 设计 


步骤 054 返回 到 “代码 ”窗口 ， 输 入 查询 数据 库 命令 : 


<?php 
$username=$_POST['username']; 
$sql=mysqli query ($conn,"select * from member where username='".$username."'"); 
$info=mysqli fetch array($sql); 
if ($info==false) 
echo "<script>alert (' 无 此 用 户 !') ;history.back();</script>"; 
exit; 
. 
else 
echo $info['question']; 
} 


?> 

步骤 064 最 后 将 “问题 提示 ”的 相关 字段 绑 定 到 网 页 中 ， 并 绑 定 传 给 下 一 页 的 隐藏 字段 ， 
如 图 4-56 所 示 。 

// 绑 定 隐藏 字段 传递 给 下 一 页 用 于 识别 身份 。 


<input type="hidden" name="username" value="<?php echo $username;?>"> 


Dw zmn mad sev eM In Sm nas ecm same Sa. © [lol¥ 


CE 











可 © W116enat, kz 


图 4-56 绑 定 字段 
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4.5.2 ”完善 查询 功能 


当 用 户 在 showquestion.php 页 面 中 输入 答案 ， 单 击 “ 提 交 ” 按 钮 后 ， 服 务 器 就 会 把 用 户 名 和 密 
人 码 提示 问题 的 答案 提交 到 showpassword.php 页 面 中 。 


下 面 介绍 如 何 设计 该 页 面 ， 具 体制 作 步 骤 如 下 : 


步 又 014 执行 菜单 栏 “文件 ” 一“ 新建 命令 ,在 网 站 根 目录 下 新 建 一 个 名 为 showpassword.php 
的 网 页 并 保存 。 


步 又 024 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 完成 如 图 4-57 所 示 的 静态 部 分 。 


Dw 六 #m wa Em ND IRM su0) Nels) gCW) sam 


-0 
硒 基 Wl ~ 











CC 
Cow SN Fi 





图 4.57 showpassword.php 静态 设计 
步 又 034 设置 记录 集 查 询 命令 : 
<?php 
include ("conn.php"); 
$username=$_POST['username']; 
$answer=$_POST['answer']; 


// 按 上 一 页 传递 过 来 的 用 户 名 查询 答案 


$sql=mysqli_query ($conn,"select * from member where username='".$username."™'"); 
$info=mysqli fetch array($sql); 


if($info['answer'] !=$answer) 
{ 


echo "<script>alert (' 提 示 答 案 输入 错误 !') ;history.back();</script>"; 
exit; 
} 
else 
{ 
2 


步骤 044 将 记录 集中 username 和 password 两 个 字段 分 别 添加 到 网 页 中 ， 如 图 4-58 所 示 。 
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图 4-58 加 入 的 记录 集 效果 
4.5.3 ”查询 密码 功能 测试 


开发 完成 查询 密码 的 功能 之 后 ， 就 可 以 测试 执行 的 情况 ， 进 行 测试 的 步骤 如 下 : 
步骤 014 启动 浏览 器 ， 在 地 址 中 输入 http:/127.0.0.1/memberindex.php， 打 开 index.php 首 页 ， 


单 击 该 页 面 中 的 “ 找 回 密码 ” 超 链接 进入 找 回 密码 页 面 ， 如 图 4-59 所 示 。 
ee 已 也 127.0.0.1 mberh 一 - 5 v ra- > 


ce) 





~ vy 
首 页 用 户 登录 用 户 注册 |， 资料 修改 密码 查询 
9 有 
密码 喜光 
罕 上 电脑 


NAW A 


ee | ®@ 
ten 


图 4-59 输入 要 查询 的 用 户 名 
步骤 024 当 用 户 进 入 密码 查询 页 面 lostpassword.php 后 ， 输 入 并 向 服务 器 提交 自己 注册 的 用 


户 名 信息 。 若 输入 不 存在 的 用 户 名 并 单 击 “ 提 交 ” 按 钮 ， 则 会 显示 用 户 名 不 存在 的 错误 信息 ， 如 图 
4-60 所 示 。 
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图 4-60 输入 用 户 不 存在 


步骤 034 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 按 钮 。 浏览 器 会 自 
动 转 到 showquestion.php 页 面 ， 如 图 4-61 所 示 。 接 着 在 showquestion.php 页 面 中 输入 问题 答案 ， 测 试 
showquestion.php 网 页 的 执行 情况 。 





EE 
€ |lo)la) lw [® np mia700 Lmembeinowauston pnp 





图 4-61 showquestion.php 网 页 效果 图 


步骤 044 在 这 里 可 以 先 输入 一 个 错误 的 答案 , 检查 showpassword.php 是 否 能 够 显示 问题 答案 
不 正确 时 的 错误 信息 ， 如 图 4-62 所 示 。 


CE I 
FX OH PMODImm oN [ER 
D © Dem [Cwm 























图 4-62 出 错 信息 
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步 最 054 如 果 在 showquestion.php 网 页 中 输入 正确 的 答案 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 浏 览 器 
就 会 转 到 showpassword.php 页 面 ， 并 显示 出 该 用 户 的 密码 ， 如 图 4-63 所 示 。 


[EE Ee 
TI EE 





Co 














图 4-63 showpassword.php 页面 
上 述 测试 结果 表明 ， 密 码 查询 系统 已 经 测试 成 功 。 用 户 管理 系统 的 常用 功能 都 已 经 设计 并 测 
试 成 功 , 读者 如 果 需 要 将 其 应 用 到 其 他 的 网 站 上 ， 只 需要 修改 一 些 相关 的 文字 说 明 及 背景 效果 ， 就 
可 以 完成 用 户 管理 系统 的 制作 ,在 注册 的 字段 采集 时 也 可 以 根据 网 站 的 需求 进一步 增加 数据 表 字段 
的 值 。 
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新 闻 管理 系统 主要 实现 对 新 闻 的 分 类 ， 发 布 ， 模 拟 了 一 般 新 闻 媒 介 的 发 布 的 过 程 。 新 闻 管 理 
系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 , 让 用 户 及 时 了 解 行业 信息 、 企 业 状况 以 
及 需要 了 解 的 一 些 知识 。PHP 实 现 这 些 功能 相对 比较 简单 ， 涉 及 的 主要 操作 就 是 访问 者 的 新 闻 查 
询 功 能 ， 系 统管 理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 ， 技 术 难点 在 于 如 何在 同一 个 页 面 上 同时 建立 
多 个 查询 记录 集 并 分 别 显示 应 用 ， 并 能 够 使 用 like 命 令 实 现 关 键 词 的 查询 功能 。 本 章 就 介绍 使 用 
PHP 开 发 一 个 新 闻 系 统 的 方法 。 


本 章 的 学 习 重 点 : 

新 闻 管 理 系统 网 页 结构 的 整体 设计 

新 闻 系 统 数据 库 的 规划 

新 闻 管理 系统 前 台新 闻 的 发 布 功能 页 面 的 制作 
新 闻 管 理 系 统 分 类 功能 的 设计 

新 闻 管理 系统 后 台新 增 、 修 改 、 人 删除 功能 的 实现 


第 5 章 ”全程 实例 三 ， 新 闻 管理 系统 


医 国 新 闻 管 理 系统 的 规划 


使 用 PHP 开 发 的 新 闻 管 理 系统 , 在 技术 上 主要 体现 为 如 何在 首页 上 显示 新 闻 内 容 , 以 及 对 新 闻 
及 新 闻 分 类 的 修改 和 删除 。 一 个 完整 的 新 闻 管理 系统 共 分 为 两 大 部 分 动态 网 页 , 一 个 是 访问 者 访问 
新 闻 的 动态 网 页 ， 另 一 个 是 后 台 管 理 者 对 新 闻 进行 编辑 的 动态 网 页 。 





5.1.1 系统 的 页 面 设计 


在 本 地 站 点 上 建立 站 点 文件 夹 news， 用 于 存放 将 要 制作 的 新 闻 管 理 系统 文件 夹 和 文件 ， 如 图 
5-1 所 示 。 














图 5-1 站 点 规划 文件 夹 和 文件 
本 系统 页 面 共 有 18 个 ， 整 体系 统 页 面 的 功能 与 文件 名 称 如 表 5-1 所 示 。 
表 5-1 ”新闻 管理 系统 网 页 功能 


index.php 显示 新 闻 分 类 和 最 新 新 闻 页 面 
type.php 分 类 中 的 新 闻 标题 页 面 


















news_add.php 增加 新 闻 的 页 面 


更 新 新 闻 的 页 面 
保存 更 新 新 闻 动态 页 面 























news_del.php 删除 新 闻 的 页 面 
savedel.php 保存 新 闻 删 除 动态 页 面 
增加 新 闻 分 类 的 页 面 
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( 续 表 ) 


删除 新 闻 分 类 的 页 面 
保存 删除 新 闻 动 态 页 面 


5.1.2 ”系统 的 美工 设计 


本 新 闻 管理 系统 实例 在 色调 上 选择 蓝 色 作 为 主 色调 ， 网 页 的 美工 设计 相对 比较 简单 ， 创 意 为 
一 个 人 在 读 取 国 内 外 的 新 闻 ， 完 成 的 新 闻 系 统 首页 index.php 效 果 如 图 5-2 所 示 。 
































图 52 首页 ndex php 效果 图 
新 闻 管 理 系统 的 后 台 也 是 重要 的 ， 实 例 登 录 后 台 的 效果 如 图 $-3 所 示 。 
































医 本 系统 数据 库 的 设计 


制作 一 个 新 闻 管 理 系统 ,首先 要 设计 一 个 存储 新 闻 内 容 、 管 理 员 账 号 和 密码 的 数据 库 文件 ， 
方便 管理 人 员 对 新 闻 数 据 信息 进行 管理 和 完善 。 
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5.2.1 新 闻 数 据 库 设 计 

新 闻 管 理 系统 需要 一 个 用 来 存储 新 闻 标 题 和 新 闻 内 容 的 新 闻 信 息 表 news， 还 要 建立 一 个 
新 闻 分 类 表 newstype 和 一 个 管理 信息 表 admin。 

制作 的 步骤 如 下 : 


步骤 01 和 在 phpMyAdmin 中 建立 数据 库 news， 单 击 马 数 据 库 命令 打开 本 地 的 “数据 库 ” 管 理 
页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 news， 单 击 后 面 的 数据 库 类 型 下 拉 按 钮 ， 在 
弹出 的 下 拉 列 表 框 中 选择 utf8_general ci 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返 回 “ 常 规 设置 ”页 面 ， 在 数 
据 库 列表 中 就 已 经 建立 了 news 的 数据 库 ， 如 图 5-4 所 示 。 
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图 5-4 创建 news 数据 库 


步骤 024 单 击 左边 的 news 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数 据 表 ” 页 面 ， 分 别 输 入 数据 表 
名 news、newstype 和 admin 即 创建 3 个 数据 表 。 创 建 的 news 数 据 表 如 图 5-5 所 示 。 
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~ 图 5-5 创建 的 news 数据 表 
输入 数据 域名 以 及 设置 数据 域 位 的 相关 数据 ， 数 据 表 news 的 字段 说 明 如 表 5-2 所 示 。 
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表 5-2 新闻 数 据 表 news 














意义 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
新 闻 编 号 news id i 

新 闻 标题 news title 

新 闻 分 类 编号 news type 

新 闻 内 容 news_content 

新 闻 加 入 时 间 news date date 是 











新 闻 作 者 | news_author varchar 20 


步骤 03 人 创建 的 newstype 数 据 表 用 于 存储 新 闻 分 类 用 ,输入 数据 域名 以 及 设置 数据 域 位 的 相 
关 数 据 ， 如 图 5-6 所 示 。 








EE CE 
CO 会 日 127.0.041 sv 
D | © | Dssao 127.001 1 127.001 1 news / news E 
phpMyAdmin 上 上 
全 号 中 亲人 





荐 太吉 网 医 佳 空 加 认 本 外 
ET 






本 EE EE Le 


司 5 BN 生 M4 户主 后 厄 必 -同系 引 国 全 文 检 











newstype 数 据 表 的 字段 及 说 明 如 表 5-3 所 示 。 
表 5-3 ”新 闻 分 类 数据 表 newstype 











意义 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
分 类 编号 type id int 11 是 
分 类 名 称 | type_name Varchar 50 | 是 | 





步骤 044 创建 的 admin 数 据 表 用 于 后 台 管 理 者 登录 验证 使 用 输入 数据 域名 以 及 设置 数据 域 
位 的 相关 数据 ， 如 图 5-7 所 示 。 


admin 数 据 表 的 字段 及 说 明 如 表 5-4 所 示 。 
表 5-4 ”管理 信息 数据 表 admin 

















意义 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 id 自动 编号 长 整 型 

用 户 名 usemame 文本 50 是 

密码 password 文本 50 是 
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A Md to contral oumms 。 与 Raman bom cenbal camms 
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图 5-7 创建 的 admin 数据 表 
在 创建 上 述 的 3 个 数据 表 时 ， 其 中 有 涉及 新 闻 保 存 时 的 时 间 保 存 问题 ， 使 用 PHP 实 现 获 取 系 统 
默认 即时 时 间 ， 可 以 使 用 两 种 方法 ， 一 种 是 在 网 页 PHP 中 用 date0 和 time() 函 数 实现 ， 另 一 种 是 直接 
在 MySQL 数 据 库 中 添加 Now() 函 数 来 获取 当前 时 间 , 考虑 到 因为 后 期 数据 量 大 需要 减少 服务 器 的 工 
作 量 ,我 们 优先 采用 在 网 页 使 用 PHP 获 取 时 间 的 方法 , 具体 的 实现 方法 在 新 增 新 闻 页 面 的 设计 时 会 
讲 到 。 


5.2.2 ”创建 系统 站 点 


在 Dreamweaver CC 2017 中 创建 一 个 “新 闻 管理 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数 据 库 网 
站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 5-5 所 示 。 


表 5-5 站 点 设置 参数 


站 点 名 称 nw 
本 机 根 目录 
测试 服务 器 






























网 站 测试 地 址 http://127.0.0.1/news 

MySQL 服 务 器 地 址 D:xampp\mysql\data\news | 
管理 账号 / 密码 root / 空 | 
数据 库 名 称 news | 





创建 news 站 点 的 具体 操作 步骤 如 下 : 


步 又 01 人 首先 在 D:xampp\htdocs 路 径 下 建立 news 文 件 夹 ( 如 图 5-8 所 示 ) ， 系 统 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 
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se 加 = 


图 5-8 建立 站 点 文件 夹 news 


步骤 02 和 运行 Dreamweaver CC 2017， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 5-9 所 示 。 

















图 5-9 “管理 站 点 ”对 话 框 


步骤 03 人 对 话 框 的 上 边 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 单 击 右 下 角 的 “新 
建站 点 ”按钮 打开 “站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 5-10 所 示 的 参数 设置 。 
站 点 设置 对 象 news x 
后 reanveever 站 点 时 网 站 中 使 用 的 所 有 文件 各 尖 的 作 合 。preamweaver 站 
; Sas i 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 > 
站 点 名 称 : news 
本 地 让 上 文件 去， D:Vampp hdocs pews\ 加 
Cm) CW ) 








图 5-10 建立 news 新 闻 站 点 
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步骤 04 人 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [也 | ， 


打开 “基本 ” 
选项 卡 ， 进 行 如 图 5-11 所 示 的 参数 设置 。 

















就 点 设置 对 银 news x 
3 | 
ws | se 总 
5 巴 如 有 re 
这 全 方法 ， 二 地 /5 = 
用 务 吕 文件 天 ，Dzyanp hdoc 所 
Web URL: [Eees 
全 了 
Cwm ) CHR jC ) | 和 碌 











图 5-11 “基本 ”选项 卡 设置 
步 最 054 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 


步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP _ MySQL 选项， 表示 是 使 用 PHP 开 发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-12 所 示 。 


站 点 设置 对 象 news 


x 

i 本 这 有 
《Css 预 处 玉 “远程 服务 器 
高 级 设置 图 维护 同步 信息 

口 保存 时 自动 振 文件 上 传 到 服务 器 

口 启用 文件 取出 功能 

打开 文件 之 前 取出 
取出 名 称 : 
电子 邮件 地 址 : 


测试 服务 器 
服务 器 模型: | PHP MySQL SS 





编 种 朋 


将 文件 自动 推送 到 铀 式 服 务 器 
口 始终 自动 保存 相关 文件 

















图 512 设置 “高 级 ”选项 卡 


步骤 064 单 击 “ 保 存 ” 按 钮 ， 返回 “服务 器 ”设置 界面 ， 选 中 “测试 ” 单 选 按 钮 ， 如 图 5-13 
所 示 。 


155 


PHP 7.0 + MySQL 网 站 开发 全 程 实 例 





就 点 役 置 对 银 news x| 
i ute 
》 CSS 预 处 理 各 
全 地 二 连接 远程。 测 可 
TH 
保存 于 自动 推进 
i * 要 共用 文件 的 自动 推送， 请 编辑 服 





Cm ) CW CR 
图 5-13 选择 “测试 ” 单 选 按钮 
步骤 074 单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 2017 中 就 已 经 拥 
有 了 刚才 所 设置 的 站 点 news。 单 击 “完成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ,这 样 就 完成 了 在 
Dreamweaver CC 2017 中 测试 新 闻 管理 系统 网 页 的 网 站 环境 设置 。 





5.2.3 ”数据 库 连接 
建立 站 点 后 ， 要 在 Dreamweaver CC 2017 中 连接 news 数 据 库 ， 连 接 新 闻 管 理 系 统 与 数据 库 的 步 
又 如 下 : 


步骤 014 将 设计 的 本 章 静 态 文件 复制 到 站 点 文件 夹 下 , 新 建立 conn.php 页 面 , 输入 连接 news 
的 代码 ， 如 图 5-14 所 示 。 


DW zw am mA TART smo wy eoW wm Be. 61 [一 





号 口 


加 加 和 对 














cH 二 号 闪 37 沾 一 
图 5-14 ”建立 数据 库 news 的 连接 代码 
<?php 
/ /建立 数据 库 连接 ; 


$conn=mysqli connect ("localhost","root","","news"); 


// 设 置 字符 为 utE-8，@ 抑 制 字符 变量 的 声明 提醒 。 
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@ mysqli set charset ($conn,utf8); 
@ mysqli query ($conn,utf8); 
/ /如果 连 接 错误 显示 错误 原因 。 
if (mysqli connect errno($conn)) 
{ 
echo "连接 MySQL 失败 : " . mysqli _connect error(); 
1 


?> 
步骤 024 设置 “连接 名 称 ” 为 news、“MySQL 服 务 器 ”名 为 localhost、“ 用 户 名 ”为 root、 
密码 为 空 。 


医 芝 通 新 闻 系统 页 面 


新 闻 管 理 系统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 用 来 访问 的 首页 新 闻 主 页 面 
index.php， 新 闻 分 类 信息 页 面 ype.php， 新 闻 详 细 内 容 页 面 newscontent.php。 


5.3.1 新 闻 系 统 主页 面 设 计 


在 本 小 节 中 主要 介绍 新 闻 管 理 系统 的 主页 面 index.php 的 制作 , 在 index.php 页 面 中 主要 有 
显示 最 新 新 闻 的 标题 , 加 入 时 间 ， 显 示 新 闻 分 类 , 单 击 新 闻 中 的 分 类 进入 分 类 子 页 面 查看 新 闻 
等 功能 。 

制作 的 步骤 如 下 : 


步骤 01 打开 刚 创建 的 index.php 页 面 ， 输 入 网 页 标题 “新 闻 首 页 ”， 执 行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 将 网 页 保存 。 


步骤 024 单 击 创建 表格 的 第 1 行 单元 格 ， 输 入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ”标签 ， 
将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index.php 这 个 页 面 使 用 的 数据 表 是 news 和 
newstype， 首 先 建立 新 闻 分 类 的 “记录 集 (查询 ) ”命令 ， 由 于 要 在 index.php 这 个 页 面 中 显示 数据 
库 中 所 有 新 闻 分 类 的 标题 ， 因 此 需要 加 入 数据 循环 遍历 所 有 newstype 中 的 数据 : 


<?php 
$sql2=mysqli_query($conn,"select * from newstype order by type_id asc"); 


// 设 置 hewstype 数 据 表 按 ID 升 序 排序 查询 出 所 有 数据 
while($info2=mysqli_ fetch array($sql2)) 


// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 ， 并 定义 为 $info2 
{ 
?> 
步 最 034 设置 记录 集 后 ， 将 记录 集 的 相关 字段 插入 至 index.php 网 页 的 适当 位 置 。 除 了 显示 
网 站 中 所 有 新 闻 分 类 标题 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链接 来 实现 详细 内 容 的 阅读 ， 
为 了 实现 这 个 功能 首先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字段 ， 然 后 加 入 跳 转 至 type.php 网 页 并 传 
递 type_id 值 。 


<a href="type.php?type_ id=<?php echo $info2['type id'];?>"> 
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<?php echo $info2['type name'];?> 
</a> 


步骤 044 主页 面 index.php 中 新 闻 分 类 的 制作 已 经 完成 ， 接 下 来 完成 最 新 新 闻 的 页 面 设 计 ， 
效果 如 图 5-15 所 示 。 








后 本 入 对 











图 5-15 设计 结果 效果 图 
步骤 054 先 制作 中 间 “ 最 新 新 闻 ” 的 显示 并 分 页 ， 编 写 代码 的 方法 和 前 几 章 节 从 数据 库 中 
查询 并 创建 “记录 集 (查询 ) ”， 最 后 进行 分 页 的 命令 是 一 样 的 : 
<?php 
$sql=mysqli query($conn,"select count(*) as total from news "); 
// 建 立 统计 有 记录 集 总 数 查询 
$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 
$total=$info['total']; 
// 定 义 变量 Stotal 值 为 记录 集 的 总 数 
ifE($total==0) 
4 
echo "本 系统 暂 无 任何 查询 数据 !"; 


} 
// 如 果 记录 总 数 为 0 则 显示 无 数据 
else 
{ 
人 
步 最 064 由 于 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 
新 闻 标 题 链接 至 详细 内 容 来 阅读 ， 首 先 选取 “查看 ”文字 ， 如 图 5-16 所 示 。 





图 516 选择 新 闻 分 类 标题 “查看 ” 
步骤 07 和 在 “ 届 性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 对 
话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 newscontentphp， 如 图 5-17 所 示 。 
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全 改 晶 其 








文件 各 (Ni | newscontentphp ~| 所 文件”) 4 
i 记 本 [而 


图 5-17 选择 链接 文件 


步骤 084 单 击 “ 确 定 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 <a hre 人 = 
"newscontent.php?news_id=<?php echo $info1[mews_ id']:?>"> 查 看 </a>。 将 参数 名 称 命名 为 news_id， 


如 图 5-18 所 示 。 
层 性 = 
《>Hmt 检 tt(F) 无 ~ 类 [无 2 医 1 
cs mm 天 ~ 由 [eo ime ln> ~] 
单元 格 水平 四 默认 不 执行 (0) 口 。 背 景 着 色 (6) 三 | 
让 三 中 -高 H) 标量 四 口 
图 5518 “动态 数据 ”对 话 框 
步 最 094 当 记 录 集 超过 一 页 ， 就 必须 要 有 “上 一 页 ”“ 下 一 页 ”等 按钮 或 文字 ， 让 访问 者 
可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 分 页 ”的 功能 。 
<table width="583" border="0"> 
E> 


<td> 共 有 数据 

<?php 

echo $total;// 显 示 总 页 数 

?> 

&nbsp; 条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ， 
&nbsp; 第 &nbsp;<?php echo $page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;// 打 印 总 页 码 数 ?>gnbsp; 页: 

<?php 


if ($page>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
{ 








怒 


~ Ww) 





面 硬 | 
已 
ED 











<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> / 
<a href="index.php?id=<?php echo $id;?>&amp;page=<?php echo $page-1;?>" title=" 
前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 
| 
if($pagecount<=4){ 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 


for ($i=1;$i<=$pagecount; $i++) { 
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> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
1 
}elsef{ 
for ($i=1; $i<=4; $i++) { 
有 2 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 
<a href="index.php?page=<?php echo $page-1;?>" title=" 后 一 页 "><font face= 
"webdings"> 8 </font></a> <a href="index.php?id=<?php echo $id;?>&amp;page=<?php 
echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php }?></td> 
</Er> 
</table> 


步骤 104 、index.php 这 个 页 面 需 要 加 入 “查询 ”的 功能 ， 这 样 新 闻 管 理 系统 才 不 会 因 日 后 数 

据 太 多 而 有 不 易 访问 的 情形 发 生 ， 设 计 效果 如 图 5-19 所 示 。 
查询 主题 : [ EU 
图 5-19 搜索 主题 设计 

利用 表单 及 相关 的 表单 组 件 来 实现 以 关键 词 查询 数据 的 功能 , 需要 注意 图 5-20 所 示 的 内 容 都 在 
一 个 表单 之 中 , “查询 主题 ”后 面 的 文本 框 的 命名 为 keyword,， “查询 ”按钮 为 一 个 提交 表单 按钮 。 

步 又 11 和 在 此 要 将 之 前 建立 的 记录 集 sql 进 行 一 下 更 改 ， 打 开 “ 折 分” 窗口， 在原 有 的 SQL 
语句 中 加 入 一 段 查询 功能 的 语句 : 

where news title like '%".S$keyword."s%' 

那么 以 前 的 SQL 语 句 将 变 成 如 下 所 示 。 


$sql=mysqli_query($conn,"select count (*) as total from news where news title 
like '%".$keyword."%$'"); 





Es A 
Ry 二 站) 


其 中 like 是 模糊 查询 的 运算 符 ，% 表 示 任意 字符 ， 而 keyword 是 个 变量 ， 代 表 关 键 词 。 


步骤 12 和 切换 到 代码 设计 窗口 。 在 页 面 的 前 面 如 下 代码 : 

$keyword=$_POST[keyword]; 

定义 keyword 为 表单 中 keyword 的 请 求 变量 ， 如 图 5-20 所 示 。 

步 最 134 以 上 的 设置 完成 后 ，index.php 系 统 主页 面 就 有 查询 功能 了 ， 先 在 数据 库 中 加 入 两 
条 新 闻 数 据 ， 可 以 按 下 F12 键 至 浏览 器 测试 一 下 是 否 能 正确 地 查询 。index.php 页 面 会 显示 网 站 中 所 
有 的 新 闻 分 类 主题 和 最 新 新 闻 标题 ， 如 图 5-21 所 示 。 
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图 5-20 加 入 代码 
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图 5-21 ”主页 面 浏览 效果 图 


步骤 144 在 关键 词 中 输入 “新 闻 二 ”并 单 击 “ 查 询 ” 按 钮 ， 结 果 显 示 在 查询 结果 页 面 中 只 
包含 有 关 “ 新 闻 二 ”的 最 新 新 闻 主 题 ， 这 样 查询 功能 就 完成 了 ， 效 果 如 图 5-22 所 示 。 





EE mi [=H1 
COD 127001 ET 
DIO | Demo [ee + [二 









om 
Start your "mASADAL 























TE EE 


图 5-22 测试 查询 效果 图 
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5.3.2 ”新 闻 分 类 页 面 设计 


新 闻 分 类 页 面 type.php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index.php 页 面 中 的 任何 一 
个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设计 效果 如 图 5-23 所 示 。 


EET EE 3 
CG 全 位 口 127.0.0.1 rAdAbd 
D | © De Ee + Bo 





< _ PHP 新 闻 管 理 系统 “人 EREEIOIRITDZEEE 


nn 人 
ASADAL \, 


半日 的 而 国 二 可 和 站 
地 定 超 : 到 i 的 条 闻 三 评 组 内 
:I 闻 五 本 得 站 
















共有 教 据 3 人 条 ， 和 页 旺 示 5 杂 ， 第 1 页 / 划 1 页 : 上 
图 5-23 新 闻 分 类 页 面 效果 
详细 的 操作 步骤 如 下 : 
步 艰 014 执行 菜单 栏 “ 文 件 ” 一 “新 建 ”命令 创建 新 页 面 ， 输 入 网 页 标题 “新 闻 分 类 ”， 
执行 菜单 栏 “ 文 件 ” 一 “保存 ”命令 ， 在 站 点 news 文 件 夹 中 将 该 文档 保存 为 type.php。 
步骤 024 新 闻 分 类 页 面 和 首页 面 中 的 静态 页 面 设计 差不多 ， 在 这 里 不 作 详细 说 明 。 
步骤 034 type.php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news， 
使 用 条 件 查询 来 显示 “记录 集 ”， 创 建 的 命令 如 下 : 
<?php 
$sql=mysqli_ query($conn,"select count (*) as total from news where news type= 
"$type_id.""); 
// 建 立 统计 有 记录 集 总 数 查 询 ， 查 询 条 件 为 新 闻 分 类 的 ID 为 首页 传递 过 来 的 ID 值 
$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 
$total=$info['total']; 


// 定 义 变量 $total 值 为 记录 集 的 总 数 
if($total==0) 


上 

echo "本 系统 暂 无 任何 查询 数据 !"; 
} 
// 如 果 记 录 总 数 为 0 则 显示 无 数据 ; 
else 


<?php 


Spagesize=57 


// 设 置 每 页 显示 5 条 记录 
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if ($total<=$pagesize){ 
$pagecount=1; 

// 定 义 $pagecount 初 始 变 量 为 1 页 ; 
} 


if(($totals$pagesize) !=0){ 
$pagecount=intval ($total/$pagesize)+1; 
// 取 页 面 统计 总 数 为 整数 ; 
}elsef{ 
S$pagecount=$total/$pagesize; 
} 
if((@ $ GET['page'])==""){ 
Spage=17 
// 如 果 总 数 小 于 5 则 页 码 显示 为 1 页 ; 
}elsef 
$page=intval($ GET['page']); 
// 如 果 大 于 5 条 则 显示 实际 的 总 数 ; 
} 


$sqll=mysqli query($conn,"select * from news where news type=".$type_id." 
order by news_id asc limit ".($page-1)*$pagesize.",$pagesize "); 
// 设 置 news 数 据 表 按 ID 升 序 排序 查询 出 首页 传递 过 来 的 值 ; 
while($infol=mysqli fetch array($sql1)) 
// 使 用 mysqli_fetch_array 查 询 所 有 记录 集 ， 并 定义 为 $infol; 
i 





Epa 
步骤 044 绑 定 记录 集 后 , 将 记录 集 的 字段 插入 至 type.php 网 页 中 的 适当 位 置 如 图 5-24 所 示 。 
动 cvamppntdocsrews\ype php* -Ox 
TSY revs php 








"ASADAL 
































上 as le | ED 上 ne 上 ne a 
图 524 插入 至 type.php 网 页 中 
步 最 054 选取 文字 “详细 内 容 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 
文件 ”图 标 , 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 newscontent.php， 如 图 5-25 所 示 。 


步骤 064 单 击 “ 确 定 ” 按 钮 ， 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 <a 
href="newscontent.php?news_id=<?php echo $infol['news_id"]; ?>"> 详 细 内 容 </a>. 将 参数 名 称 命名 为 
news_id， 如 图 5-26 所 示 。 
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全 OneDrive 

EL. 

国 滴 所 

EL 至 comnphp 

图 阁 Binderphp 

a 了 newscontentphp 

可 ypephp 

国 训 而 

计 本 地 二 和 (C:) 

一 FD 、。 最 

于 | 六 人 ~ 
文件 名 (N): newsccntentphp “| | 所 有 文件 信 ") ~ 
Wena | [| Ws |][ ws 
图 5-25 ”选择 链接 文件 

属性 到 
Hm 格式 们 无 类 (无 BJ 党 咎 和 举 举 相 是 中 
县 css DD) 元 ~ ” 提 接 (0 [php echo Snfoi[fnews_d]; ?| ~]@e 目标 (6) J 
基本 | 单元 格 。 水 平 (z) 黑人 ~ 更 W)，20% 不 换行 (0) 口 背景 颜色 (G) 三 ra 
于 加 放生 直 (T) 虚 人 人 ~ 高 2 本 要 加 口 











图 5-26 “参数 ”对 话 框 
步骤 D7 和 、 和 首页 一 样 加 入 记录 集 分 页 功能 , 特别 注意 所 有 指向 要 为 本 页 即 type.php 这 个 名 称 


的 网 页 ， 代 码 如 下 : 


<?php 

echo $total;// 显 示 总 页 数 ; 

2 

&nbsp; 条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ， 


&nbsp; 第 &nbsp;<?php echo S$page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;// 打 印 总 页 码 数 ?>&nbsp; 页: 


<a 


<?php 
if ($page>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
。 
<a href="type.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> / 
href="type.php?id=<?php echo $id;?>&amp;page=<?php echo S$page-1;?>" title=" 


前 一 页 "><font face="webdings"> 7 </font></a> 
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<?php 
} 
if($pagecount<=4) { 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 
for ($i=1;$i<=$pagecount; $i++){ 
> 
<a href="type.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
上 
}elsef{ 
for ($i=1; $i<=4; $i++) { 
> 
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<a href="type.php?page=<?php echo $i;?>"><?php echo $i;?></a> 

<?php }?> 

<a href="type.php?page=<?php echo S$page-1;?>" title=" 后 一 页 "><font face= 
"webdings"> 8 </font></a> <a href="type.php?id=<?php echo $id;?>gamp;page=<?php 
echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 

<?php 

3 

?> 


到 这 里 新 闻 分 类 页 面 type.php 的 设计 与 制作 就 已 经 完成 ， 编 辑 完 成 的 页 面 如 图 5-27 所 示 。 
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图 5-27 完成 设置 后 的 编辑 页 面 


5.3.3 ”新 闻 内 容 页 面 设计 


新 闻 内 容 页 面 newscontent.php 用 于 显示 每 一 条 新 闻 的 详细 内 容 , 这 个 页 面 设计 的 重点 在 于 如 何 
接收 主页 面 index.php 和 type.php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 中 相应 的 数据 。 新 
闻 内 容 页 面 的 设计 效果 如 图 5-28 所 示 。 
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D | © | Os 加 12700.1/news/newacentert ohoIr x | 二 -于 -)】 
< PHP 新 闻 管 理 系统 对 多 最 新 新 闻 | 新 闻 分 类 | 后 全 管理 
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nASADAL BN 





新 间 标 新 : 负 试 新 间 一 
新 间 咎 容 : 和 六 条 闻 二 注册 容 











图 5-28 新 闻 内 容 页 面 设计 效果 图 
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详细 的 操作 步骤 如 下 : 


步 又 014 执行 菜单 栏 “文件 ”一 “新 建 ”命令 创建 新 页 面 ， 执 行 菜单 栏 “ 文 件 ”一 “保存 ” 
命令 ， 在 站 点 news 文 件 夹 中 将 该 文档 保存 为 newscontent.php。 


步 又 024 新 闻 内 容 页 面 设计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-29 所 示 。 


DW zen wa ew AN IRD an am ceo san .0 


人 











图 5-29 新 闻 内 容 页 面 设计 效果 图 
步骤 034 首先 创建 “记录 集 (查询 ) ”， 查 询 的 条 件 为 news_id: 


<?php 

require_ once('conn.php'); 

Snews_id=@ $_GET['news_id']; 

?> 

<?php 

$sql=mysqli_query($conn,"select * from news where news_ id=".$news_id.""); 
// 建 立 统计 有 记录 集 总 数 查 询 ， 查 询 条 件 为 新 闻 分 类 的 ID 传递 过 来 的 ID 值 ; 
$info=mysqli fetch array($sql); 

// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 ; 

?> 


步骤 044 创建 记录 集 后 ， 将 记录 集 的 字段 插入 至 newscontent.php 页 面 中 的 适当 位 置 ， 这 样 
就 完成 了 新 闻 内 容 页 面 newscontentphp 的 设置 ， 如 图 $-30 所 示 。 


aa cae sn 可 Wi AD) Dan EW smh 











ee 





图 5-30 绑 定 字段 
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国 双 后 台 管理 页 面 


新 闻 管 理 系统 的 后 台 管 理 对 于 网 站 很 重要 ， 管 理 者 可 以 由 这 个 后 台 增 加 、 修 改 或 删除 新 闻 内 
容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 系 统管 理 登录 入 口 页 面 的 设计 效果 如 图 
5-31 所 示 。 





350 安 全 浏览 器 9.1 > 只 文件 下 看 《 芒 I 具 帮 芭 | 曾 一 口 ，X 
所 | 台 | 合 | 龙 | 回 t 127.0.01 


D> 各 至 吉本 录 反 





户 : 
码 : 


用 
庶 





5-31 ”系统 管理 入 口 页 面 


5.4.1 后 台 管理 登录 


后 台 管 理 主 页 面 必须 受到 权限 管理 ， 可 以 利用 登入 账号 与 密码 来 判别 是 否 由 此 用 户 来 实现 权 
限 的 设置 管理 。 

详细 操作 步骤 如 下 : 

步 又 014 执行 菜单 栏 “文件 ” 一“ 新建” 命令， 创建 新 页 面 ， 输 入 网 页 标题 “管理 者 登录 ”， 
执行 菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文 件 夹 中 的 admin 文 件 夹 中 将 该 文档 保存 为 
admin_login.php。 

步 野 024 执行 菜单 “插入 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

步骤 034 将 光标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 对 话 
框 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 4; 在 “ 列 ” 文 本 框 中 输入 需要 插入 表格 的 列 数 2; 
在 “表格 宽度 ”文本 框 中 输入 400 像 素 ; 其 他 的 选项 保持 默认 值 ， 如 图 5-32 所 示 。 









































Table x 
RE 
5 4 到 2 
要 格 直 要，400 人 素 
党 : 0。 你 条 
单元 奖 边 更 :0 贺 
单元 基 庆 更 :[0 | 国 

等 题 
| 可 | 二 ed bd 
再 动 习 能 
将 是 
所 三 
C 融 W)C 
图 5-32 插入 表格 
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步骤 04M 人 和 单 击 “确定 ”按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 “属性 ” 
面板 中 设置 “水 平 ” 为 “居中 对 齐 ”。 拖 动 鼠 标 选中 第 1 行 表格 的 所 有 单元 格 ， 在 “属性 ”面板 中 
单 击 “ 合 并 ” 回 按 钮 ， 将 第 1 行 表格 合并 。 用 同样 的 方法 将 第 4 行 合并 。 
步 蛇 054 在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管理 中 心 ”， 在 表格 的 第 2 行 第 1 个 单元 
格 中 输入 文字 说 明 “ 用 户 : ”， 在 表格 的 第 2 行 第 ?个 单元 格 中 单 击 “ 文 本 域 ”按钮 回 ， 插 入 单行 
文本 域 表 单 对 象 ， 定 义 文本 域名 为 username，“ 文 本 域 ” 属 性 设置 如 图 5-33 所 示 。 
和 | 

















加 文本 域 字符 宽度 0) | | 类 型 〇 单行 (5) 。” 〇 多 行 名 密码 (F) 类 (C) | 无 ~ 
fosernme | 最 多 字符 数 | | 初始 值 C) | 9 
口 禁 用 如) 
口 R 读 的) 


图 5-33 ”输入 “账号 ”名 和 插入 “文本 域 ”的 设置 
步骤 064 在 第 3 行 表格 中 ,输入 文字 说 明 “ 密 码 : ”, 在 表格 的 第 3 行 第 ?个 单元 格 中 单 击 “ 文 
本 域 ”按钮 回 ， 插 入 单行 文本 域 ， 定 义 文本 域名 为 password，“ 文 本 域 ” 属 性 设置 如 图 5-34 所 示 。 
st Eeee====es_sm»»==ss=-= = 














文本 域 字符 宽度 (0) | 类 型 〇 单行 G) ” 〇 多 行 如 。”@ 密 码 (PP) ”类 (C0) | 无 v 
assvord 最 字符 数 | 初始 值 DI 8 

口 莫 用 @) 

口 R 读 人 


图 5-34 输入 “密码 ”名 和 插入 “文本 域 ” 的 设置 
步 邓 07 人。 单 击 选择 第 4 行 单元 格 ， 执 行 两 次 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 ， 插 入 
两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 一 个 为 
“ 重 设 表单 ”选项 ，“ 属 性 ”的 设置 分 别 如 图 5-35 和 图 5-36 所 示 。 
屋 性 








按 锯 名称 值 (v) 提交 动作 @ 提交 表单 (s) 口 无 中 类 (C) [无 ~ 


[avit | OR 站 











图 5-35 设置 按钮 名 称 的 属性 1 








按钮 名 称 值 (Y) 重 轩 动作 〇 提交 表单 G) 〇 无 0) 类 (C0) | 无 ~ 











Fa 回 重 设 表单 四 





图 5-36 设置 按钮 名 称 的 属性 2 
步骤 08 角 在 标签 栏 选择 <form> 标 签 ,设置 跳 转 到 chkadmin.php 页 面 进 行 验证 , 如 图 5-37 所 示 。 
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图 5-37 登录 用 户 的 设 定 
步骤 094 新 建立 一 个 chkadmin.php 动 态 页 面 输入 验证 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$username=$_POST['username']; 
$userpwd=$_POST['password']; 
class chkinput{ 
var $name; 
Var $pwd; 
function chkinput ($x, $y){ 
$this->name=$x; 
$this->pwd=$y; 
. 
function checkinput (){ 
include ("conn.php"); 
$sql=mysqli query($conn,"select * from admin where username='".$this-> 
name."'"); 
$info=mysqli _ fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 管理 员 名 称 输入 错误 ! ');history. 
back();</script>"; 
exit; 
} 
else{ 
if($info['password']==$this->pwd) 
证 
session start()7 
$_SESSION['username']=$info['username']; 
header ("location:admin.php"); 
exit; 
} 
elae dl 
echo "<script language='javascript'>alert(' 密码 输入 错误 ! 
') ;history.back(); </script>"; 
exit; 
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1 
} 
} 
’ 
S$obj=new chkinput (trim($username),trim($userpwd)); 
S$obj->checkinput (); 
?> 


步骤 104 返回 到 编辑 页 面 ， 完 成 后 台 管理 入 口 页 面 admin_login.php 的 设计 与 制作 。 


5.4.2 ”后 台 管 理 主 页 面 


后 台 管理 主页 面 是 管理 者 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 增 、 修 改 或 
能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 结构 如 图 5-38 所 示 。 
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图 5-38 后 台 管理 主页 面 效 果 图 


























详细 操作 步骤 如 下 : 


步 又 014 由 于 admin.php 的 大 部 分 查询 功能 和 index.php 页 面 的 功能 是 一 样 的 ， 因 此 可 以 直接 
打开 index.php 页 面 ， 将 其 另存 为 admin.php 网 页 ， 在 index.php 基 础 上 进行 文字 说 明 修 改 以 及 更 改 单 
击 时 的 链接 地 址 即 可 ， 另 存 修改 的 动态 页 面 如 图 5-39 所 示 。 





























图 5-39 后台 管理 主页 面 效 果 图 
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步 又 024 。 admin.php 是 提供 管理 者 链接 至 新 闻 编辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 ， 设 置 了 6 个 链接 ， 各 链接 的 设置 如 表 5-6 所 示 。 
表 5-6 admin.php 页 面 的 链接 设置 























[名 称 链接 页 面 | 

| 添加 新 闻 分 类 type_add.php | 

| 更 新 新 闻 分 类 type_up.php | 

| 删除 新 闻 分 类 type_del.php | 

| 添加 新 闻 news_add.php | 

| 更 新 新 闻 news_upd.php | 
删除 新 闻 news_del.php 





其 中 “修改 ”及 “删除 ”的 链接 必须 要 传递 参数 给 转 到 的 页 面 ， 这 样 转 到 的 页 面 才能 够 根据 
参数 值 而 从 数据 库 将 某 一 笔 数据 筛选 出 来 再 进行 编辑 。 

步骤 034 首先 选取 "添加 新 闻 ”, 在 “属性 ”面板 中 将 它 链接 到 admin 文 件 夹 中 的 news_add.php 
页 面 。 

步骤 044 选取 右边 栏 中 的 “修改 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 
览 文件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 news_upd.php， 如 图 5-40 所 示 。 


国运 文件 x 


组 织 > 。 新 建立 件 





conn.php 






EL 
六 news addphp 
4 news_delphp 
本 newsupdphp 
水 三 ype addphp 
加 吉本 ype delphp 2017/2114 15:01 
各 本 地 区 盘 (Cj SE ype updphp 2017/211415:01 

















i 到 应 
图 5-40 选择 链接 文件 
步 最 054 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 <a hre 全 "mews_upd.php?news id 
=<?php echo $infol['news_id”];?>"> 修 改 </a>， 如 图 5-41 所 示 。 











层 性 a 
Com 二 四 无 ~ 类 (无 DBI 杜 是 中 @® 
上 css DD 无 ~ 袍 接 (D) [3php echo Snfoi[news_d]3> ~| 目标 (6) 和 

加 村 |。 单元 格 。 水平 四。 默认 ~ 宽 (wW) 7 种 行 (9) 口 ”背景 颜色 (c) [| 人 C 页 而 属性， | 
瑟 天 放生 直 ( 点 人 ~ 高 (HW) 村 是 四 口 | 











图 541 “属性 ”面板 设置 链接 
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步骤 064 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news_delphp， 并 传递 新 
闻 标 题 的 ID 参数 <a hre 仁 "news_del.php?news_id=<?php echo $info1[mews_ id]:?>"> 删 除 </a>， 如 图 
5-42 所 示 。 











Com 格式 (F) 无 ~ 本 是 中 ) @ 
杷 css Im 元 且 目标 (96) 
画面 | 单元 格 。 水平 站。 默认 ~ 宽 (W) 换行 (9) 口 ”背景 颜色 (G) [了 | (《 页面 属 性 











次 ”本 直人 点 人 ~ 高 (H) 村 是 固 口 
图 5-42 设置 传递 至 news_del.php 
步骤 07 人 和 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文 件 夹 中 的 type_upd.php 链 接 并 传递 


type_id 参 数 [<a hre 伍 "type_upd.php?type_id=<?php echo $info2['type_id"];?>"> 修 改 </a>]， 如 图 5-43 所 





尾 性 至 
CF HL 格式 (F) 无 ~ 类 ( 殉 DBI 汪 时 上 涯 站 机 © 
旧 css ID 元 ~ 链 缠 中 type_upd.php?type_jid=<2.. ~ 包扎 目标 (6) ~ 

加 号 | 单元 格 水平 四 昧 从 ~ 宽 (w) 下 换行 (9) 口 ”背景 颜色 (G) [| (页 面 必 性 … 
一 一 其 要 直 m 点 人 ~ 高 (H) 标题 (6) 口 











图 5-43 设置 传递 至 type_upd.php 


步骤 08 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 细节 页 面 改 为 type_del.php 并 传递 
type_ id 参数 [<a href="type_del.php?type_id=<?php echo $info2['type_id"];?>"> 删 除 </a>]， 如 图 5-44 所 





OE 格式 (F) 无 ~ 类 ( 殉 了 BJI 注 过 和 泽 站 ”本 中 ©® 
旧 css IO 无 ~ 甸 姜 加 bpe_dalphpzype id=<. ~ 图 白 目标 (6) ~ 

瑟 到 单元 格 水 平 名 内 ~ 寓 W) 换行 (9) 口 背景 颜色 (c) 全 | (页面 属性 ， | 
EH = 一 | 











站 要 直 0m 赋 人 ~ 高 (H) 标题 (E) 口 
图 5-44 设置 传递 至 type_del.php 


步 野 094 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文 件 夹 中 的 
type_add.php 页 面 。 


步骤 104 后 台 管 理 是 管理 员 在 后 台 管 理 入 口 页 面 admin_login.php 输 入 正确 的 账号 和 密码 才 
可 以 进入 的 一 个 页 面 ,所 以 必须 设置 限制 对 本 页 的 访问 功能 。 这 里 实现 的 方法 有 很 多 种 ， 最 简单 的 
就 是 使 用 session 变 量 ， 通 过 判断 $ SESSION['username'] 是 否 为 空 来 限制 访问 ， 实 现 的 代码 放 在 页 面 
的 最 前 面 : 


<?php 

session start(); 

require once('conn.php'); 

$keyword=@ $_POST['keyword']; 

if(@ $_SESSION['username']=="") 

{ 

echo "<script>alert (' 您 还 没有 登录 ,请 先 登 录 !') ;history.back();</script>"; 
exit; 


} 
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?> 
限制 访问 的 效果 页 面 如 图 5-45 所 示 。 
| 








图 5-45 直接 登录 出 现 错误 提示 
步 又 114 单 击 “ 确 定 ” 按 钮 ， 就 完成 了 后 台 管理 主页 面 admin.php 的 制作 。 
5.4.3 ”新 增 新 闻 页 面 
新 增 新 闻 页 面 news_add.php， 设 计 的 页 面 效果 如 图 5-46 所 示 ， 实 现 了 插入 新 闻 的 功能 。 


DW zw was mem mA IRM BMD A gOW 和 Se 0 











a oN (3 全 CC B115I0SBW, 局 
ee cow 对 TH 王 





图 5-46 新 增 新 闻 页 面 设计 
详细 操作 步骤 如 下 : 


步 又 014 创建 news_add.php 页 面 ， 本 页 制作 有 三 个 核心 技术 ， 其 一 是 如 何 从 MySQL 数 据 库 
中 查询 出 新 闻 的 分 类 并 显示 到 下 拉 列 表 框 中 ; 其 二 是 提交 时 自动 获得 系统 的 时 间 ; 其 三 是 单 击 “ 添 
加 ”按钮 时 需要 对 提交 的 表单 进行 验证 ， 首 先 看 一 下 验证 的 实现 方法 : 
<script language="javascript"> 
function chkinput (form) 
{ 


if(form.news title.value=="") 
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alert ("请 输入 新 闻 标题 !"); 
form.news title.select(); 
return (false); 


if(form.news author.value=="" 


alert ("请 输入 作者 !"); 
form.news_author.select (); 
return (false); 


if(form.news_ content .value=="") 


alert ("请 输入 年 龄 !")， 
form.news_content.select (); 
return (false); 
} 
return(true); 
} 
</script> 


步骤 024 绑 定 记录 集 后 ，“ 新 闻 分 类 ”的 下 拉 列 表 框 能 显示 分 类 ， 实 现 的 办 法 是 循环 遍历 
<option> 所 有 值 ， 并 设置 <option> 的 value 值 即 可 ， 代 码 如 下 : 


<label> 
<select name="news type" id="news_ type"> 
<?php 
$sql=mysqli query($conn,"select * from newstype"); 
while($info=mysqli fetch array($sql)) 
{ 
全 二 
<option value="<?php echo $info['type_id'];?>">// 获 取 分 类 的 ID 编 号 
<?php echo $info['type_name'];?>// 显 示 分 类 名 称 
</option> 
<?Pphp 
; 
Ep 
</select> 
</label> 


加 入 代码 运行 效果 如 图 5-47 所 示 。 





青 添加 新 闻 : 


新 闻 标题 : 











图 547 “动态 列表 /菜单 ”效果 


步骤 034 本 页 面 制作 的 第 二 个 技术 重点 就 是 要 使 用 PHP 实 现 自动 获取 系统 的 默认 时 间 ， 当 
插入 新 闻 时 能 自动 生成 当时 的 时 间 。 方 法 是 绑 定 一 个 隐藏 字段 并 命名 为 news_date， 切 摘 到 代码 行 
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将 值 设置 如 下 。 


<input name="news date" type="hidden" id="news date" value="<?php 
echo date("Y-m-d"); 
二 


// 设 置 时 间 格 式 并 显示 当时 时 间 


步骤 044 在 news add.php 编 辑 页 面 , 单 击 “ 添 加 ”按钮 能 提交 到 saveadd.php 页 面 ,使 用 INSERT 
INTO 语 句 可 以 实现 插入 记录 的 操作 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

include ("conn.php"); 

Snews_ title=$_ POST['news title']; 

$news_type=$_POST['news type']; 

$news_author=$_POST['news author']; 
$news_content=$_POST['news_content']; 
$news_date=$_POST['news_ date']; 

mysqli query($conn,"insert into news (news title,news type,news_content, 

news_author,news_date) 

values('S$news title','S$news type','$news author','$news_content', 
'$news_date')"); 

echo "<script>alert (' 添 加 成 功 !') ;history.back();</script>"; 





?> 
返回 到 编辑 页 面 ， 就 完成 hews_add.php 页 面 的 设计 了 ， 最 后 的 编辑 页 面 如 图 5-48 所 示 。 
DW zm wae wa WA ZR ao as OW woe TIE 
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”图 5-48 “插入 记录 ”命令 


5.4.4 更 新 新 闻 页 面 


更 新 新 闻 页 面 news_upd.php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修改 , 修改 
数据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-49 所 示 。 


175 


PHP 7.0 + MySQL 网 站 开发 全 程 实例 





DW zy mme sem EA IE sun si ED mm S52. 0 


er de “IEE 
ee 
ER tr! WR! 
| 
si: | ee 
EE > 








凶 











an 














En 
om ER 
广东 和 是 更 得 入 是 ER- 元 [5 3 寺 训 地 贡 昌 各 井中， ET 
图 5-49 更 新 新 闻 页 面 设计 本 
详细 操作 步骤 如 下 : 


步 又 014 打开 news_upd.php 页 面 ,该 页 面 与 新 增 新 闻 页 面 中 的 分 类 调用 方法 是 一 样 的 , 但 在 
该 页 显示 的 是 单 击 “ 更 新 ”文字 链接 传递 过 来 的 news_id 值 调用 相应 的 新 闻 显示 到 页 面 上 ， 然 后 修 
改 后 提交 更 新 到 数据 库 中 。 

步骤 024 由 于 代码 都 差不多 这 里 只 列 出 查询 记录 集 不 同 的 地 方 ， 使 用 where 条 件 查 询 
news_id=-'$news_id'， 代 码 如 下 : 


<?php 
$news_id=$_GET['news_id']; 
$sql=mysqli_query($conn,"select * from news where news_ id='$news_id'"); 
$info=mysqli fetch array($sql); 
?> 


步骤 034 传递 到 saveupdate.php 的 更 新 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
$news_id=$_POST['news_id']; 
$news_title=$_POST['news title']; 
$news_date=$_POST['news date']; 
Snews_type=$_POST['news_type']; 
$news_content=$_POST['news_content']; 
$news_author=$_POST['news_author']; 
include ("conn.php"); 
mysqli query($conn,"update news set news title='$news title',news date= 
'$news_date',news_ type="'$news type',news_content='$news_content',news_author=" 
$news_author' where news_id='$news id'"); 
echo "<script>alert (' 修 改 成 功 !') ;history.back();</script>"; 
2 
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人 
Ee 
MB, 


这 里 一 定 要 注意 更 新 时 所 有 字段 要 一 一 对 应 ， 即 可 以 完成 更 新 新 闻 页 面 的 设计 。 


5.4.5 ”删除 新 闻 页 面 


删除 新 闻 页 面 news_del.php 和 更 新 新 闻 页 面 差 不 多 ， 可 以 直接 将 上 面 制作 的 更 新 新 闻 页 面 另 
存 ， 再 修改 一 下 说 明文 字 即 可 ， 如 图 5-50 所 示 。 其 方法 是 将 表单 中 的 数据 从 站 点 的 数据 表 中 删除 。 
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图 550 删除 新 闻 页 面 的 设计 
步 又 01 4 单 击 “ 删 除 ”按钮 提交 到 savedel.php 动 态 页 面 进行 处 理 ， 代 码 如 下 : 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

include ("conn.php"); 

Snews_id=$_POST['news_id']; 

mysqli_query ($conn,"delete from news where news_ id='$news id'"); 
// 根 据 传递 过 来 的 TD 来 删除 新 闻 

echo "<script>alert (' 删 除 成 功 !');</script>"; 
// 删 除 成 功 跳 转 到 admin .php 页 面 
header ("location:admin.php"); 
?> 


步 又 024 完成 删除 新 闻 页 面 的 设计 。 


5.4.6 ”新 增 新 闻 分 类 页 面 


新 增 新 闻 分 类 页 面 type_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 newstype 数 据 表 中 ， 页 面 设 
计 如 图 5-51 所 示 。 
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人 替 p:wampp\htdocs\news\admin\type_add.php = 
请 添加 新 闻 分 类 : 
新 闻 分 类 名 称 : 
重 置 
一 6 Bo- | an 
| 400= 





RU LE ED 器 5axl ~ 加 
图 5-51 新 增 新 闻 分 类 页 面 设计 


步 又 014 单 击 “添加 ”按钮 时 ， 跳 转 到 type_add_save.php 实 现 增加 分 类 的 功能 ， 具 体 的 代码 
如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$type_name=$_POST['type name']; 
mysqli_query ($conn,"insert into newstype (type_name) values ('$type name')"); 


echo "<script>alert (' 添 加 成 功 !');history.back();</script>"; 
?> 


步 又 024 完成 type_add.php 页 面 设计 。 


5.4.7 更 新 新 闻 分 类 页 面 


更 新 新 闻 分 类 页 面 type_upd.php 的 功能 是 将 数据 表 的 数据 传递 到 页 面 的 表单 中 进行 修改 ,修改 
数据 后 再 更 新 至 数据 表 中 ， 页 面 设计 效果 如 图 5-52 所 示 。 





入 pvampp\ntdocs\news\admin\type_upd php i 
代码 conn.php 了 
有 和 
请 修改 新 闻 分 类 
分 类 名 称 : [<?php echo $info[ type -| 四 
修改 重 置 
body 。 fom zfoml 加 569xl66 ~ 图 


图 5-52 更 新 新 闻 分 类 页 面 设计 


步 又 014 设置 记录 集 查询 功能 ， 并 绑 定 分 类 名 称 和 隐藏 分 类 主 字 段 ， 方 便 数 据 传递 并 更 改 ， 
核心 的 代码 如 下 : 
<?php 
$type_id=$_GET['type_id']; 
// 从 上 一 页 接收 type_id 表 单 变量 
$sql=mysqli query($conn,"select * from newstype where type id='$type id'"); 


$info=mysqli fetch array($sql); 
区 
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步 又 024 、 单 击 type_upd.php 页 面 中 的 “修改 ”按钮 时 ， 跳 转 到 type_upd_save.php 实 现 修改 分 
类 的 功能 ， 具 体 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 


<?php 
include ("conn.php"); 
$type_name=$_ POST['type name']; 


$type id=$ POST['type id']; 
mysqli_ query ($conn, "update newstype set type name='$type name'where type id= 


'$type_id'"); 

echo "<script>alert (' 更 新 成 功 !') ;</script>"; 
header ("location:admin.php"); 

?> 


步骤 03 完成 更 新 新 闻 分 类 页 面 的 设计 。 


5.4.8 删除 新 闻 分 类 页 面 
删除 新 闻 分 类 页 面 type_del.php 的 功能 ， 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 删除 。 
详细 操作 步骤 如 下 : 
步 又 014 打开 type_delphp 页 面 ， 该 页 面 和 新 闻 更 新 的 页 面 类 似 。 绑 定 记录 集 后 ， 将 记录 集 


的 字段 插入 至 type_delphp 网 页 中 的 适当 位 置 ， 如 图 5-53 所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 
= 


刚 0:wampp\htdocs\news\admin\type_delphp 
源 代码 》 conn.php 村 
请 修改 新 闻 分 类 : ; 
分 类 名 称 : [<5pbp echo $infot" type-| 回 
曙 除 ”“ 重 置 
EE | 








body fom tabe rr dd EBD :en 569x168 ~ 加 


图 5-53 字段 的 插入 
步骤 024 单 击 “ 删 除 ” 按 钮 ， 提 交 到 type_del_ save.php 网 页 中 进行 删除 处 理 ， 代 码 如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 


include ("conn.php"); 
$type_id=$_POST['type id']; 

mysqli query($conn,"delete from newstype where type id='$type id'"); 
echo "<script>alert (' 删 除 分 类 成 功 !') ;</script>"; 
header ("location:admin.php"); 


人 


一 个 实用 的 新 闻 管 理 系统 就 此 开发 完毕 ， 读 者 可 以 将 本 章 开 发 的 新 闻 管 理 系统 的 方法 应 用 到 


实际 的 大 型 网 站 建设 中 去 。 
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全 程 实例 四 : 在 线 投票 管理 系统 


网 站 的 投票 管理 系统 设置 好 投票 主题 之 后 ， 网 站 的 会 员 积 极 参与 可 以 起 到 活跃 会 员 ， 增 加 浏 
览 量 的 作用 。 一 个 投票 管理 系统 可 分 为 3 个 主要 的 功能 模块 : 投票 功能 、 投 票 处 理 功 能 以 及 显示 投 
票 结果 功能 。 投 票 管理 系统 首先 给 出 投票 选 题 ( 即 供 投票 者 选择 的 表单 对 象 ) ， 当 投票 者 单 击 选 择 
投票 按钮 后 ,投票 处 理 功能 被 激活 ， 对 服务 器 传送 过 来 的 数据 做 出 相应 的 处 理 , 先 判断 用 户 选择 的 
是 哪 一 项 ， 累 计 相应 项 的 字段 值 ， 然 后 对 数据 库 进行 更 新 ， 最 后 将 投票 的 结果 显示 出 来 。 


本 章 的 学 习 重 点 : 

@ 投票 管理 系统 站 点 的 设计 
@ 投票 管理 系统 数据 库 的 规划 
@ 计算 投票 的 方法 

@ 防止 刷新 的 设置 
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轩 对 二 在线 投票 管理 系统 规划 


在 线 投票 管理 系统 在 设计 开发 之 前 ， 对 将 要 开发 的 功能 进行 一 下 整体 的 规划 。 本 实例 将 实现 3 
个 部 分 页 面 内 容 的 设计 ， 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 面 ， 三 是 用 来 提供 选择 的 页 面 。 


6.1.1 页 面 规划 设计 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 , 在 本 地 站 点 上 建立 站 点 文件 夹 vote, 将 要 制作 的 投 
票 管理 系统 的 文件 夹 和 文件 如 图 6-1 所 示 。 


加 1 回国 1 vowe 二 吕 ， 秘 
| = 0 
刚 EE 
+ 罗 自 纪 LX Dum em 
国定 到 快 s 和 和 Lod 村 3 y oy 
于 坊间 文人 = ” 友和 四 





中 
三 pc-201210118TBT 
量 QH-20150829TPJA 


家 
ve > 


8 个 项 目 园 电 
图 6-1 站 点 规划 文件 


本 实例 制作 的 投票 系统 共有 5 个 页 面 ， 页 面 的 功能 与 文件 名 称 如 表 6-1 所 示 。 
表 6-1 在 线 投票 系统 网 页 设计 表 


页 面 名 称 
在 线 投票 管理 系统 的 首页 
数据 库 连 接 调用 文 伯 


统计 投票 的 功能 


sorry.php 投票 失败 页 面 








6.1.2 ”系统 页 面 设计 


票 管理 系统 的 页 面 共 4 个 ， 包 括 开始 投票 页 面 、 计 算 投 票 页 面 、 显 示 投 票 结果 页 面 以 及 投票 
失败 页 面 。 计 算 投 票 页 面 voteadd.php 的 实现 方法 是 : 接收 vote.php 页 面 所 传递 过 来 的 参数 然后 执行 
累加 的 功能 ， 为 了 保证 投票 的 公正 性 ， 本 系统 根据 他 地 址 的 唯一 性 设置 了 防止 页 面 刷新 的 功能 。 开 
始 投票 页 面 和 显示 投票 结果 页 面 的 设计 效果 如 图 6-2 和 图 6-3 所 示 。 
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图 6-2 投票 管理 系统 首页 


革 汪 系统 数据 库 的 设计 


本 节 主 要 介绍 投票 管理 系统 数据 库 的 连接 方法 ， 投 票 管理 系统 的 数据 库 主 要 用 来 存储 投票 选 


项 和 投票 次 数 。 


6.2.1 数据 库 设计 


投票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 地 址 的 


数据 表 ip。 
制作 的 步骤 如 下 : 


步 最 014 在 phpMyAdmin 中 建立 数据 库 vote， 选 择 局 数据库 命令 打开 本 地 的 “数据 库 ” 管 理 
页 面 ， 在 “新 建 数 据 库 ” 文本 框 中 输入 数据 库 的 名 称 vote, 单 击 打开 后 面 的 数据 库 类 型 下 拉 列 表 框 ， 
选择 utf8_general_ci 选 项， 单 击 “创建 ”按钮 ， 返 回 “ 常 规 设置 ”页 面 ， 在 数据 库 列表 中 就 已 经 建 


立 了 vote 的 数据 库 ， 如 图 6-4 所 示 。 





EE 

二 已 会 会 如 hrp/127.00.1, 

[Le [Urns 01 /127001 [poyram ”| + 
phpMyAdmin FEE ， 


全 而 由 而 全 
过 期 访问 于 由 
四 


三 所 和 二 关 提 所 风情 







3 入 话 且 50 训 拓 万 时 用 训 户 加 号 出 了 更 吉 


= 3 





图 6-3 投票 结果 显示 页 面 


风量 127 DLL vi 
Tcp/ 正 
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步 又 024 单 击 左边 的 vote 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
ip 和 vote ( 即 创建 2 个 数据 表 ) 。 创 建 ip 数据 表 (字段 结构 见 表 6-2 ) ， 用 于 限制 重复 投票 使 用 ， 输 


入 数据 域名 以 及 设置 数据 类 型 的 相关 数据 ， 如 图 6-5 所 示 。 














表 6-2 ip 数据 表 
意义 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 ID int 长 整 型 
投票 的 p 地 址 voteip varchar 245 | 是 








9 127.0.0.1 






Db © | Da 全 访 127.001/1270011vote /iplph> 二 
phpMyAdmin EE 
目 济 向 纹 信物 回 saL 人 检索 防 其 入 豆 5 出 更 多 
i Er 3 去 拉 构 不 关 素 和 加 





归 作 










寺村 


FEE 局 兴 全 时 下子 
LO NI vs 


国 叭 





ak 办 
Remore! 














图 6-5 创建 的 ip 数 据 表 
步骤 034 设计 vote 数 据 表 用 于 存储 投票 的 选项 和 投票 的 数量 , 输入 数据 域名 以 及 设置 数据 域 


位 的 相关 数据 ， 如 图 6-6 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 vote 的 字段 结构 如 表 


6-3 所 示 。 
表 6-3 ”投票 数据 表 vote 


[Em ID |m lu 中 | 
| 扫 票 E 题 |iem jvahar | | 是 | 
FT 


Er 
€ 全会 hapa7001 
1270011127001 1 vo /vo | |+ 已 > 













DO | Dass 
PR 全 如 


a 人 


(RE 二 作 


NEENT 少 尼 国有 的 w 王 
Da O Ws v ES 
CO MS vES 





直人 
A cade Remowe hom central colamns 











1 过 附 。 于 ws 之 后 [Ea 


图 6-6 vote 数据 表 





本 
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步骤 044 为 了 方便 后 面 系统 开发 的 需要 ， 先 在 vote 数据 表 里 加 入 4 个 投票 的 数据 ， 单 击 “ 浏 
览 ” 选 项 卡 ， 在 数据 表 手 动 加 入 名 为 选项 1 至 选项 4 的 四 个 选择 模式 ， 如 图 6-7 所 示 。 






三 360 窑 全 询 扣 头 31 Ws [= IOT Xx 
所 CE 会昌 127.0.0.1 登 乡 v 
Bo 

~ 用 二 -= 娄 二 目 





者 守 甘 插 A 国 5 vv 时 








由 Be o 有 三 了 页 国 刚 际 1 A 10 
dy. 沪 册 和 二 制 因 是 盾 2 BB 6 
昌 避 wow 避 ciP 有 每 卫 责 制 加 出 际 3 5 9 
portornance schena anh j 
3 phpmaanin SS 
人 日 人 束 丰 直上 M 险 轧 引 d 
由 日 vte 
ED 且 去 全 娟 行 数 ， | 25 ，| 过 通行 
Bsio 
Fj vore 有 “mn 结果 县 作 


”图 6-7 输入 投票 选择 
数据 库 创 建 完毕 ， 可 以 发 现在 线 投票 管理 系统 的 数据 库 相 对 比较 简单 。 





6.2.2 ”投票 管理 系统 站 点 


在 Dreamweaver CC 2017 中 创建 一 个 “投票 系统 ”网 站 站 点 vote， 由 于 这 是 PHP 数 据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 6-4 所 示 。 


表 6-4 ”在 线 投票 管理 系统 站 点 基本 参数 


站 点 名 称 [we 
本 机 根 目录 
测试 服务 器 
网 站 测试 地 址 
MySQL 服 务 器 地 址 
管理 账号 /密码 


数据 库 名 称 
创建 vote 站 点 的 具体 操作 步骤 如 下 : 
步 双 014 首先 在 D:\xampp\htdocs 路 径 下 建立 vote 文 件 夹 ( 如 图 6-8 所 示 ) ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 
步骤 024 运行 Dreamweaver CC 2017， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 6-9 所 示 。 
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图 6-8 建立 站 点 文件 夹 vote 

















CSS ) CS ) 
CE CG 
图 6-9 “管理 站 点 ”对 话 框 
步骤 034 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 方 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 图 6-10 所 示 的 参数 设置 。 








站 点 设置 对 象 vote x 
MN = 
py Cs 站 证 果 风 站 中 人 有 的 上 文件 和 光合 ，oooeeee 站 
点 并 时 全 
》 css 预告 bl 下 的 有 生息 夫 介 。 
， 高 时 
您 可 以 在 此 处 为 Dreamweaver 站 点 过 择 本 地 文件 夫 和 名 称 。 
站 点 名 称 : vote 
本 地 站 点 文件 天 : D:Varpphtdbcswore\ [3 
Cw ) Cm ) 








图 6-10 建立 vote 站 点 
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步 双 04 人 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 生 ]， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 6-11 所 示 的 参数 设置 。 








站 点 设置 对 杀 vote x 
站 6 
| 及 器 | 一 
Css 预 处 于 服务 器 名 称 : vote 
A 连接 方法 ; 本 地 /R 咯 ~ 
服务 器 文件 夫 : D:yampphtdocs [=] 
Web URL: [Pep//127.0.0.1otel 
| 
Cm ) CR _ 〇 Cwm ) | 入 




















图 6-11 “基本 ”选项 卡 设置 
步 最 054 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信息 ” 复 选 框 , 在 “服务 器 模型 ”下拉 列 表 框 中 选择 PHP MySQL (表示 是 使 用 PHP 开 发 的 网 页 ) ， 
其 他 的 保持 默认 值 ， 如 图 6-12 所 示 。 





站 点 设置 对 象 vote 
| = 
os 远程 服务 器 
高 级 设置 加 维护 同步 信息 
口 保存 时 自动 持 文件 上 传 到 服务 器 
口 自用 文件 职 出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 














坟 模 服 

















图 6-12 设置 “高 级 ”选项 卡 
步骤 06 人 单 击 “ 保 存 ” 按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 单 选 按钮 ， 如 图 6-13 
所 示 。 
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站 二 设置 对 象 vote 
您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Re Interet 服务 提供 商 (ISP) 或 Web 管理 员 。 
Ed 地 址 连接 运程 。 测 式 
十 一 
SC ee mm 
Cm ) CW )( 名 ) 

















图 6-13 设置 “服务 器 ”参数 
步 台 07 色 单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 在 Dreamweaver CC 2017 中 就 已 经 拥 
有 了 刚才 所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 在 
Dreamweaver CC 2017 中 测试 在 线 投票 系统 网 页 的 网 站 环境 设置 。 


6.2.3 ”数据 库 连 接 
完成 了 站 点 的 定义 后 ， 下 面 就 是 用 户 系 统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 的 连接 设 
置 步骤 如 下 : 


步骤 D1 人 将 原 代码 vote 文 件 包 中 设计 的 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ， 打 开 vote.php 投 
票 首 页 ， 如 图 6-14 所 示 。 


DW xun wat sa WMD TAT et) 站 ct9 OW wii0 m8- oo l=lol x 











二。 11 者 有 8 这 中 , 与 3azn 二 字 节 。 
< ION SRN 司 | 





图 6-14 打开 网 站 首页 
步骤 02 人 。 新 建立 conn.php 网 页 ， 输 入 投票 系统 的 数据 库 连 接 代码 : 
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<?php 
/ /建立 数据 库 连 接 ; 
$conn=mysqli_connect ("localhost", "root","","vote"); 
// 设 置 字符 为 tf-8，@ 捉 制 字 符 变 量 的 声明 提醒 。 
@ mysqli set charset ($conn,utf8); 
@ mysqli query ($conn,utf8); 
/ /如果 连 接 错误 显示 错误 原因 。 
if (mysqli connect errno($conn)) 
echo "连接 MySQL 失败 : " . mysqli connect error(); 
} 


> 


MySQL 服 务 器 名 为 localhost 本 地 , 用户 名 为 root, 密码 为 空 。 选择 所 要 建立 连接 的 数据 库 名 称 ， 
选择 刚 建 立 的 范例 数据 库 vote， 完 成 设置 内 容 如 图 6-15 所 示 。 














ER 
sov SN Ph 


图 6-15 设置 MySQL 连接 参数 


节 到 时 在线 投票 管理 系统 开发 


对 投票 管理 系统 来 说 需要 重点 设计 的 页 面 是 开始 投票 页 面 vote.php 和 投票 结果 页 面 
voteok.php。 计 算 投 票 页 面 voteadd.php 是 一 个 动态 页 面 ， 没 有 相应 的 静态 页 面 效 果 ， 只 有 累加 投票 
次 数 的 功能 。 


6.3.1 开始 投票 页 面 功 能 


开始 投票 页 面 vote.php 主 要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 然 后 传递 
到 voteadd.php 页 面 进行 计算 。 
详细 的 操作 步骤 如 下 : 


步 又 014 打开 刚 创建 的 vote.php 页 面 ,输入 网 页 标题 “开始 投票 页 面 ”， 执 行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 将 网 页 保存 。 


步 邓 02 人。 在 刚 创 建 背景 图 像 的 单元 格 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ”一 “表单 ”命令 ， 
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再 执行 菜单 “插入 ”一 “表格 ”命令 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 表格 中 执行 菜单 栏 
“插入 ”一 “表单 ”一 “ 单 选 按钮 ” 命令， 插入 一 个 “ 单 选 按钮 ”选择 “ 单 选 按钮” 并 在 “属性 ” 
面板 中 将 它 命名 为 ID， 如 图 6-16 所 示 。 

















5| 单 和 按钮 选 定 值 U 初始 杖 态 〇 已 勾 先 (C) 类 (C) 无 ~ 


本 多 动态 .| 加 未 迁 中 人) 


图 6-16 设置 “ 单 选 按钮 ”名 称 
步骤 034 执行 菜单 栏 “插入 ”一 “表单 ”一 “按钮 ”命令 两 次 ， 插 入 两 个 按钮 ， 一 个 是 用 
来 提交 表单 的 按钮 ,命名 为 “投票 ”; 另外 一 个 是 用 来 查看 投票 结果 的 按钮 ， 命 名 为 “查看 ”， 效 
果 如 图 6-17 所 示 。 





体 ovwampp\tdocswotewvote php* -Dx 
浙大 到 -on.php 
lL : | 75% 35) | | 区 
+ Se (287) 








yu fm tbe vv dd E> @ 5s52x15l ~ | 图 
图 6-17 投票 首页 的 效果 图 
步骤 044 建立 “记录 集 (查询 ) ”功能 ， 在 打开 的 “代码 ”窗口 中 输入 查询 的 代码 : 


<?php 
$sql=mysqli_ query($conn,"select * from vote order by ID ASC"); 
while($info=mysqli fetch array($sql)) 





| 
Rs 
步骤 054 建立 记录 集 后 , 将 记录 集中 的 字段 插入 至 vote.php 网 页 的 适当 位 置 ,如 图 6-18 所 示 。 
价 pwampp\tdocswotewvotephp 本 
征 人 本 -mp 
Lies  、 i pe Pes E 
: 你 投 的 选项 是 : 上 
| oo 
: 投票 | [要 村 上 
加 | “ 
和 > 
ecno FMoL 20 J » 
4 </LabeL></td> 
48v <td width="86%"> EphoNeenolSntonn tem 
</td> 
49 </tr> 
50v <?php 
tt Tom ... table tr 划 回 PHP ~v 592xl20 ~ INS 48:27 区 


图 6-18 记录 集 的 字段 插入 至 vote.php 网 页 
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步骤 06 和 单 击 “ 单 选 按钮 ”将 字段 ID 绑 定 到 单 选 按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面 


板 中 的 “ 选 定 值 ”中 添加 了 插入 ID 字段 的 相应 代码 为 <input name="ID" type="radio" value=" <?php 
echo $info['TD'];?>" >， 如 图 6-19 所 示 。 











口 “em 初始 状态 口 已 5 选 () 
ID 


动态 .， 国 未 选中 (0 











图 6-19 插入 字段 到 单 选 按钮 
步 又 07 4 单 击 页 面 中 的 “查看 ”按钮 , 需要 提交 并 跳 转 到 voteok.php 网 页 查看 投票 后 的 结果 ， 


在 <input> 标 签 中 加 入 一 个 javascript 实 现 简单 的 判断 并 跳 转 到 相关 的 页 面 : 


<label> 

<input name="Submit" type="submit" value=" 投 票 " onclick= 
"javascript:this.form.action='voteadd.php' "/> 

<input name="Submit2" type="submit" value=" 查 看 " onclick= 
"javascript:this.form.action='voteok.php' "/> 

</label> 


步骤 084 完成 vote.php 页 面 的 制作 ， 效 果 如 图 6-20 所 示 。 
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{ 0Op 
| 因 配 
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bs DOO) ouaip Ld 
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6-20 vote.php 网 页 制作 完成 


6.3.2 ”计算 投票 页 面 功能 


计算 投票 页 面 voteadd.php， 主 要 功能 是 接收 vote.php 所 传递 过 来 的 参数 然后 进行 累加 计算 。 计 


算 投 票 页 面 voteadd.php 只 用 于 后 人 台 计 算 用 ， 希望 投票 者 在 成 功 投票 之 后 转 到 投票 结果 页 面 
voteok.php， 只 要 加 入 代码 header("location:voteok.php"); 到 voteadd.php 页 面 就 可 以 完成 对 voteadd.php 
页 面 的 制作 ， 本 小 节 的 核心 代码 如 下 : 
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<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<?php 


第 6 章 全 程 实例 四 : 在 线 投票 管理 系统 


require once('conn.php'); 
// 调 用 数据 库 连 接 
if (empty($ POST['ID'])){ 
echo "您 没 选择 投票 的 项 目 "; 
exit (0); 
}// 判 断 是 否 选择 了 投票 的 选项 
else 
{ 
$voteip=strval ($_ POST['voteip']); 
/ /赋值 变 量 voteip 为 上 一 页 传递 过 来 的 voteip 值 
$sql=mysqli query($conn,"select * from ip where voteid='".$voteip."'"); 
// 以 voteid=voteip 为 条 件 查 询 数据 表 ip 
$info=mysqli fetch array($sql); 
// 从 结果 集中 取得 一 行 作为 关联 数组 info 
if ($info==true) 


// 如 果 值 为 真 ， 说 明 数 据 库 中 有 ITP 地址， 已 经 投 过 票 
{ 


header ("location:sorry.php"); 
// 转 到 失败 页 面 sorry .php 
exit; 
} 
else 
{ 
mysqli_ query($conn,"INSERT INTO ip (voteid) VALUES ('".$voteip."')"); 
// 如 果 没有 则 将 ip 地 址 插入 到 ip 数据 表 中 
} 
$ID=strval ($_POST['ID']); 
// 赋 值 ID 变量 为 上 一 页 传递 过 来 的 ID 值 


mysqli_query ($conn, "UPDRTE vote SET vote=vote+1 WHERE ID="'$ID'"); 
// 根 据 ID 更 新 数 表 vote， 并 自动 加 一 

mysqli_close($conn); 

header ("location:voteok.php"); 


// 转 到 voteok .php 
} 
?> 
UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 


UPDATE table name 
SET column name = new value 
WHERE column name = some value 


因为 SQL 对 大 小 写 不 敏感 ， 所 以 UPDATE 与 update 等 效 。 
为 了 让 PHP 执 行 上 面 的 语句 ， 我 们 必须 使 用 mysqli_query( ) 函 数 。 该 函数 用 于 向 SQL 连接 发 送 
查询 和 命令 。 


6.3.3 ”显示 投票 结果 页 面 


显示 投票 结果 页 面 voteok.php 主 要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ,静态 页 面 设 
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计 效 果 如 图 6-21 所 示 。 


























Ey we on [ac 加 60x314 ~ 
图 6-21 显示 投票 结果 页 面 设计 效果 图 

步 又 01 人 首先 实现 第 一 行 “选项 调查 中 总 共有 多 少 人 参加 投票 ! ”功能 ， 创 建 一 个 记录 集 ， 

进入 “代码 ”编辑 窗口 ， 加 入 以 下 代码 : 









建立 记录 集 后 ， 将 <?php echo $info['total"]?> 绑 定 到 多 少 人 的 位 置 ， 如 图 6-22 所 示 。 


DW zm mm maM AN Inn mo ety OW nm |W EE 
晶 L 


3 $sql-myrqli query(Sconn, "select sum (vote) ae total from vote"); 
Sinfo-myoali Fetch-array ($sql); 























图 6-22 ”字段 的 绑 定 
步 又 024 再 建立 一 个 记录 集 查询 $sql1 用 于 显示 投票 的 内 容 并 统计 数量 。 





步 最 034 完成 记录 集 的 设置 ， 绑 定 记录 集 后 ， 将 记录 集中 的 字段 插入 至 voteok-php 网 页 中 的 
适当 位 置 ， 如 图 6-23 所 示 。 
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入 DamppntdocswoteWwoteok php -ox 
ET 
[小 计 , 吧 票 数 
body table 人 好 form tabie 区 WwW .SmLE3 回 632x284 ~ 区 





图 6-23 字段 的 插入 





步骤 044 人 。 单 击 0 画 | 按钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 图 


像 中 ， 加 入 代码 为 : 


<td width="40%"><img src="images/bar.gif" width="<?php echo round(($infol 
['vote']/$info['total']),4)*100?>" height="13" /><span class="STYLE3"> <?php echo 


round( ($infol['vote']/$info['total']),4)*100?>%</span></td> 


<td width="42%" class="STYLE3"> 小 计 : <?php echo $infol['vote']?> 票 数 </td> 


这 样 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设 置 如 图 6-24 所 示 。 


由 ovamppintdocs\vote\voteok php -Ox 
A 
wnTUeUSTnToI=mysqUT_Tercn-array(SsqLIJJ 
{ 
?> 





2 <tr bgcolor="#FFFFFF"> 

| 5 <td width="18%" height="25"><label><span 
class="STYLE3" style="text-align: center"><?php echo 

$infol['item']?></span></label></td> 

<td width="40%">&nbsp; cimg src="images/bar.gif" 

width="<?php echo 

round( (Sinfol['vote']/$info[ 'total']) ,4)*1992>" 

| ><span clas: 








</span></td> 

<td width="42%" class="STYLE3">&nbsp; 小 计 : <?php echo 
$infol['vote']?> 票 数 &nbsp; </td> 

56 </tr> 


外 oo mp ~- m2 国 


图 6-24 设置 图 像 的 缩放 
步 又 054 单 击 页 面 中 的 “返回 首页 ”链接 ， 转 到 “vote.php”， 如 图 6-25 所 示 。 














相 式 (F) 无 ~ 类 (下 BJ 泻 昌 生涯 村 m 
DD 无 ~ 0 “ee WO) 
单元 格 “水平 四 点 人 ~ 宽 (w) 不 搞 行 (0) 口 ”背景 颜色 (G) 全 | :FFFFFF 
站 本 让 四 黑人 ~ 高 ”2 本 8 回 口 














图 6-25 输入 转 到 URL 的 文件 地 址 
步骤 064 完成 显示 结果 页 面 voteok.php 的 设置 ， 测 试 预览 效果 如 图 6-26 所 示 .。 


» [lis 量 
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EE 
志 已 会 | 六 |[ 加 [mp127001oNorek pnp BEYv 












































图 6-26 显示 投票 结果 页 面 的 效果 图 


6.3.4 ”防止 页 面 刷新 功能 


一 个 投票 管理 系统 是 要 求 公平 、 公 正 的 投票 ， 不 允许 用 户 进行 多 次 投票 ， 所 以 在 设计 投票 开 
始 系统 时 有 必要 加 入 防止 页 面 刷新 的 功能 。 
实现 该 功能 的 详细 操作 步骤 如 下 : 


步 又 014 打开 开始 投票 页 面 vote.php， 把 光标 放 在 表单 中 ， 执 行 菜单 栏 “ 插 入 ”一 “表单 ” 
一 “隐藏 域 ”命令 ， 插 入 一 个 隐藏 字段 voteip。 


步骤 024 单 击 隐藏 域 一 图标， 打开 “属性 ”面板 。 设置 隐藏 域 的 值 为 <?php echo 
$_SERVER['REMOTE_ADDR'];?>， 取 得 用 户 的 人 P 地 址 ， 如 图 6-27 所 示 。 


尾 竹 至 
， | we ER 4 9 
a | ame | votep Value [SR 总 


Form ~ 


图 6-27 设置 隐藏 域 的 值 


步 最 034 将 实现 防止 刷新 的 程序 放 到 voteadd.php 页 面 里 面 ， 打 开 前 面 制 作 的 计算 投票 页 面 
voteadd.php， 在 相应 的 位 置 加 入 代码 ， 如 图 6-28 所 示 。 


痢 pvamppntdocswoteWwoteadd php -Ox 
RD ono 


Svoteip=strval($_POST['voteip']); 
/1 局 入 过 皖 vote 加 为 上 一 页 不 迪 过 习 gvotezp 售 
$sql Ui_query($conn, "select * from ip where 
voteid="",. $voteip."'"); 
15  // 妈 voteid=voteip 为 突 余 曾 询 潜 C 乌 下 ip 
16 $info=-mysqli_fetch_array($sql); 
17 //M 知 宁 生 四 肥 郑 一 /9 关 开 info 
18 if($info==true) 
19 /2 元 入 为 育 ， 详 隔 纱 可 笑 办 育 TP 妙 好， 已 绎 下 过 要 












header ("location:sorry.php"); 
BMEsorry. php 


exits 


else 





日 mp ~ ms 372 图 


图 6.28 ”加 入 防止 刷新 的 代码 
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具体 的 代码 分 析 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<?php 
require once('conn.php'); 
// 调 用 数据 库 连 接 
if (empty($ POST['ID'])){ 
echo "您 没 选择 投票 的 项 目 "; 
exit (0); 
}// 判 断 是 否 选择 了 投票 的 选项 
else 
{ 
S$voteip=strval($_POST['voteip']) 7 
// 赋 值 变量 voteipP 为 上 一 页 传递 过 来 的 voteipP 值 
$sql=mysqli_query(Sconnv "select * from ip where voteid='".$voteip."'"); 
// 以 roteid=voteip 为 条 件 查询 数据 表 ip 
$info=mysqli fetch array($sql); 
// 从 结果 集中 取得 一 行 作 为 关联 数组 info 
if ($info==true) 
// 如 果 值 为 真 ， 说 明 数 据 库 中 有 IP 地 址 ， 已 经 投 过 票 
{ 
header ("location:sorry.php"); 
// 转 到 失败 页 面 sorry .php 
exit; 
} 
else 
{ 
mysqli_query ($conn, "INSERT INTO ip (voteid) VALUES ('".$voteip."')"); 
// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数 据 表 中 
} 
$ID=strval ($_POST['ID']); 
// 赋 值 ID 变量 为 上 一 页 传递 过 来 的 ID 值 
mysqli_query ($conn, "UPDRATE vote SET vote=vote+1 WHERE ID='SID'") 
// 根 据 ID 更 新 数据 表 vote， 并 自动 加 一 
mysqli_close($conn); 
header ("location:voteok.php"); 
// 转 到 voteok .php 
} 


?> 
步骤 044 完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 IP 的 唯一 性 进行 判断 。 
当 用 户 再 次 投票 时 ， 将 转 到 投票 失败 的 页 面 sorry.php， 页 面 设计 效果 如 图 6-29 所 示 。 


E36 7.1 票 和 痢 一 口 x 


《二 全 | 太 加 127.0.0.1 BEv 








回执 x | 


对 不 起 ， 你 已 投 过 一 次 村 了 ， 请 不 要 多 次 投票 








图 6-29 投票 失败 页 面 效果 图 
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在 sorry.php 页 面 有 两 个 页 面 链 接 ,“ 回 主页 面 ”链接 到 vote.php,“ 查 看 结果 ”链接 到 voteok.php。 


轩 双 站 在 线 投票 管理 系统 测试 


投票 管理 系统 设计 完成 之 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 F12 键 或 打开 浏览 器 输入 
http://127.0.0.1/ vote/vote.php 即 可 开始 进行 测试 。 测 试 步骤 如 下 : 


步骤 014 在 浏览 器 中 打开 vote.php 文 件 ， 开 始 投票 页 面 效果 如 图 6-30 所 示 。 


EE 200 71 
专 || 张 | 会友 | 旬 
LA srr 


CORE 
127.0.0.1 F 


Elv 
* la 











加 四 
图 6-30 打开 的 开始 投票 页 面 














步骤 024 不 选择 任何 选项 ， 单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 没 选择 投票 的 项 目 ”， 如 
图 6-31 所 示 。 





站 360 安 全 济 克 器 71 于 间 | 曾 一 口 xX 
所 弛 会 | 太 加 hip//127.0.0.1 BEY 
[区 http//127.0.0.1/vote/votea: x [| 


您 没 选择 投票 的 项 目 











图 6-31 没 选择 项 目 错误 提示 
步骤 03 人 选择 投票 项 的 其 中 一 项 ， 再 单 击 “ 投 票 ”按钮 ， 开 始 投票 。 
步骤 044 单 击 “ 投 票 ”按钮 后 ， 打 开 的 页 面 不 是 voteadd.php， 因 为 voteadd.php 只 是 计算 投 


票数 的 一 个 统计 数字 页 面 ， 打 开 的 页 面 是 显示 投票 结果 页 面 voteok.php ，voteok.php 页 面 是 
voteadd.php 转 过 来 的 一 个 页 面 ， 效 果 如 图 6-32 所 示 。 
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酸 360 福 全 训 这 二 8.1 < 且 单 | 曾 一口 X | 
|4 © 全 日 httpV/127.0.01/vote/voteokphp Fv 


DIO|Dsms |im=nm x |+ 到 > 























图 6-32 显示 投票 结果 的 页 面 


步骤 05C 单 击 “ 返 回首 页 ”文字 链接 ， 回 到 投票 页 面 vote.php 中 。 当 用 户 再 次 投票 时 ， 将 打 
开 投 票 失败 的 页 面 sorry.php， 如 图 6-33 所 示 。 





逢 360 安 全 测 史 器 7.1 * 标 音 曾 一口 Xx 
€| 纺 || 会 || 太 j 旬 |http://127.0.0.1/vote/sorry.php Ev| 
国 扩 x 


对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 ! 
回 主页 面 查看 结果 











图 6-33 ”提示 已 经 投票 


通过 上 面 的 测试 说 明 该 投票 管理 系统 的 所 有 功能 已 经 开发 完毕 ， 读 者 可 以 看 到 在 线 投票 管理 
系统 的 开发 并 不 难 , 用 户 可 以 根据 需要 修改 投票 的 选择 项 , 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 
大 型 网 站 。 
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全 程 实例 五 : 留言 簿 管理 系统 


网 站 留言 簿 管理 系统 的 功能 主要 是 实现 网 站 的 访问 者 和 网 站 管理 者 的 一 个 交互 性 ， 访 问 者 可 
以 向 管理 者 提出 任何 意见 和 信息 ， 管 理 者 可 以 在 后 台 及 时 回复 。 因 此 ， 学 习 PHP 开 发 动态 网 站 时 
留言 往 管理 系统 的 学 习 也 是 必 不 可 少 的 。 本 章 将 使 用 PHP 开 发 一 个 可 以 进行 留言 并 进行 回复 的 留 
言 往 管理 系统 ,开发 的 技术 主要 涉及 数据 库 留 言 信息 的 插入 、 回 复 和 修改 信息 的 更 新 等 ,在 涉及 回 
复 时 间 时 还 会 涉及 一 些 关 于 PHP 时 间 函 数 的 设置 问题 。 


本 章 的 学 习 重 点 : 

@ 留言 簿 管理 系统 的 整体 规划 

@ 留言 簿 数据 库 的 建立 方法 

@ 留言 簿 管理 系统 常用 功能 的 设计 
@ 获取 系统 时 间 的 方法 

@ 获取 留言 者 电脑 下 地 址 的 方法 
@ 后 台 管理 系统 的 设计 


第 7 章 ”全程 实例 五 ， 留 言 簿 管理 系统 


留言 簿 管理 系统 规划 


留言 簿 管理 系统 的 主要 功能 是 在 首页 上 显示 留言 ,管理 者 能 对 留言 进行 回复 、 修 改 和 删除 ， 
因此 一 个 完整 的 留言 簿 管理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 








7.1.1 页面 规划 设计 


在 本 地 建立 站 点 文件 夹 gbook， 将 要 制作 的 留言 簿 系统 文件 夹 及 文件 如 图 7-1 所 示 。 





X 可 时 己 ned 
3 = 手 站 对 ge 














图 7-1 站 点 规划 文件 


本 系统 共有 10 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 7-1 所 示 。 
表 7-1 ”系统 页 面 说 明 表 


[mgs | 


管理 者 对 留言 内 容 进行 回复 的 页 面 
实现 保存 回复 的 动态 页 面 
管理 者 对 一 些 非法 留言 进行 删除 的 页 面 


管 言 钴 系 乡 
管理 者 对 留言 的 内 容 进行 管理 的 页 面 
管 寺 留 言 





7.1.2 系统 页 面 设 计 


网 页 设计 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 左右 布局 结构 ， 留 言 页 面 效果 
如 图 7-2 所 示 。 
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EE rm | 
CO 食品 127001 EE 
Db © |Dess | 回 ssse 十 -全 





3 可 
由 和 二 阳 有 什么 同 和 天 帮 训 的 和 ， 光 抽 名 证 过 入 久 训 ， 侈 们 全 这 时 了 入 吾 
交 | | 重 村 











EE 


ET 





















































最 本 电 区 目 目 7 a 
I 了 国王 
RS + ass 














图 7-2 留言 簿 管理 系统 首页 


世系 统 数 据 库 设计 


制作 留言 簿 管理 系统 ， 首 先 要 设计 一 个 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回复 以 及 
管理 员 账 号 、 密 码 的 数据 库 文 件 gbook， 以 方便 管理 和 使 用 。 





7.2.1 数据 库 设计 


本 数据 库 主要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ，“ 留 言 信 息 意 见 表 ” 
命名 为 gbook，“ 管 理 信息 表 ” 命 名 为 admin。 
制作 的 步骤 如 下 : 


步 野 014 在 phpMyAdmin 中 建立 数据 库 gbook， 单 击 蝇 数据 库 命 令 打 开本 地 的 “数据 库 ” 管理 
页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 gbook， 单 击 后 面 的 数据 库 类 型 下 拉 按 钮 ， 在 
弹出 的 下 拉 列 表 框 中 选择 utf8_general_ci 选 项 ， 单 击 “ 创 建 ” 按钮， 如 图 7-3 所 示 ， 返 回 “ 常 规 设置 ” 
页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 gbook 的 数据 库 。 


EEE Bx 





€ Cpa Er 

Db © Dr 和 17001117001 pewadn ”| + 已 5 
+ EE 

phpMyAdmiIn 





. Sts Ya 


会 全 
六 二 














图 7-3 开始 建 数据 表 
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步骤 024 单 击 左边 的 gbook 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 
名 gbook 和 admin ( 即 创建 ?个 数据 表 ) ， 设 计 gbook 的 字段 结构 如 表 7-2 所 示 。 输 入 字段 名 以 及 设置 
数据 类 型 的 相关 数据 ， 如 图 7-4 所 示 。 


表 7-2 ”留言 短信 息 表 gbook 









ID 





















Subject 50 | 是 
content | 是 
reply | 

date | 是 









redate 








Boerne 
€ CO mp EF 





CRNR 1 LAR Lee ne (eg 


是 
nN 
ET EE EL 
了 8 小 辐 HI 户主 省 而 恒 大作 2 








Cd 3 产 证 国 和 痢 


图 74 ”创建 的 数据 表 gbook 
步 野 034 创建 admin 数 据 表 ， 参 见 表 7-3。 用 于 后 台 管理 者 登录 验证 ， 输 入 数据 域名 以 及 设 
置 数据 域 位 的 相关 数据 ， 如 图 7-5 所 示 。 
表 7-3 ”管理 信息 数据 表 admin 











字段 名 称 数据 类 型 字段 大 小 必 填 字段 





USername Varchar 





password varchar 50 是 
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7-5 创建 的 admin 妆 据 表 
数据 库 创建 完毕 以 后 ， 对 于 本 系统 而 言 下 一 步 是 如 何 取得 访问 者 的 IP 地 址 。 


7.2.2 ”定义 系统 站 点 


在 Dreamweaver CC 2017 中 创建 一 个 “留言 簿 管理 系统 ”网 站 站 点 gbook， 由 于 这 是 PHP 数 据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 7-4 所 示 。 


表 7-4 ”站 点 设置 的 基本 参数 





站 点 名 称 gbook 





管理 账号 /密码 
数据 库 名 称 [La | 


创建 gbook 站 点 具体 操作 步骤 如 下 : 


步 又 014 首先 在 Di\xampp\htdocs 路 径 下 建立 gbook 文 件 夹 (如 图 7-6 所 示 ) ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 








图 7-6 建立 站 点 文件 夹 gbook 
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步 邓 02 和 运行 Dreamweaver CC 2017， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 
“管理 站 点 ”对 话 框 ， 如 图 7-7 所 示 。 


mss 














图 7-7 “管理 站 点 ”对 话 框 
步骤 034 对话 框 的 上 边 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 方 的 “新 
建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 7-8 所 示 的 参数 设置 。 


EREE=E 1 区 
es i 
》 Cs5 处 埋 操 全 证 队 本 和 发 布 到 we 


站 可 慑 在 此 条 为 Dyeamweever 站 点 入 和 二 地 交 件 去 和 名 和 





将 点 名 稳 ， goooc 
本 二 站 点 丸 件 天 :上 ampp hadocegaookl 国 


图 7-8 建立 gbook 站 点 


步骤 044 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 叶 ]， 打 开 “ 基 本 ” 
选项 卡 进行 如 图 7-9 所 示 的 参数 设置 。 


ea obook x 
| 至 E33 ] 
es 暗 从 其 大 称 。 gbook 
说 避 
连 榨 方 法 : 本 地 /时 2 5 
有 开关 文件 天 : Dryanpp htdocs 已 
wum [aaa | 
二 
mh Cw )C ww | 

















图 7-9 设置 “基本 ”选项 卡 
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步骤 054 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 中 “维护 同 
步 信 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选 项 ， 表 示 是 使 用 PHP 开 发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-10 所 示 。 





站 点 设置 对 象 gbook x 
| ES 
Cs 远程 服务 器 
高 级 设置 加 维护 同步 信息 
口 保 椰 时 自动 将 文件 上 传 到 服务 器 
口 自用 文件 职 出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 
电子 邮件 地 址 : 














雹 纹 用 


) | 

















图 7-10 设置 “高 级 ”选项 卡 


步骤 06 人 单 击 “ 保 存 ” 按 钮 ， 返回 “服务 器 ”设置 界面 选中 “测试 ” 单 选 按钮 ， 如 图 7-11 
所 示 。 





ait) gbook 

| 您 将 在 此 位 置 选择 承 乾 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
mr Internet 服务 提供 商 (ISP) 或 Web 管理 只。 

> EE 地 lL 庆生。 





+ 一 8 可 


保存 时 自动 推送 
A en 








Cm) Cm ) CRI 
图 7-11 设置 “服务 器 ”参数 
步 又 07 人 单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 在 Dreamweaver CC 2017 中 就 已 经 拥 
有 了 刚才 所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关闭“ 管理 站 点 ”对 话 框 ， 这样 就 完成 了 在 
Dreamweaver CC 2017 中 测试 留言 簿 管理 系统 网 页 的 网 站 环境 设置 。 
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7.2.3 ”数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 ， 网 站 与 数据 库 的 连接 
设置 如 下 : 


步骤 01 和 将 源 代码 gbook 文 件 包 中 设计 的 本 章 文件 复制 到 站 点 文件 夹 下 ， 打 开 index.php， 如 
图 7-12 所 示 。 








i 
be oh 2 
fv sth wi dd 
四 y ~ = 
FHP 国 言 办 理 系 统一 一 >“ ee 
a 











hj RE EE 





图 7-12 打开 网 站 首页 


步 又 024 单 击 菜单 栏 上 的 “文件 ” 一“ 新建” 命令， 新 建 conn.php 数 据 库 连接 文件 ， 代 码 如 
EE: 
<?php 
// 建 立 数 据 库 连 接 ; 
$conn=mysqli connect ("localhost", "root","", "gbook"); 
// 设 置 字符 为 tf-8，@ 捉 制 字 符 变 量 的 声明 提醒 。 
@ mysqli_ set charset ($conn,utf8); 
@ mysqli query($conn,utf8); 
// 如 果 连 接 错误 显示 错误 原因 。 
if (mysqli_connect errno($conn)) 
{ 
echo "连接 MySQL 失败 : " . mysqli_connect _ error(); 
} 
2> 


编辑 的 页 面 效果 如 图 7-13 所 示 。 
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Dw xen mae sam EMD IEm np) ues IW HE me- | or [=lol x] 





z 口 


i 和 但 加 导 





7-13 ”conn.php 动态 页 面 


匡 二 对 留言 簿 首页 和 留言 页 面 


留言 簿 管理 系统 分 前 台 和 后 台 两 部 分 ， 这 里 首先 制作 前 台 部 分 的 动态 网 页 ， 主 要 有 留言 竹 首 
页 index.php 和 留言 页 面 book.php。 


7.3.1 留言 首页 


在 留言 首页 index.php 中 ， 单 击 “ 留 言 ” 超 链接 时 ， 打 开 留 言 页 面 book.php， 访 问 者 可 以 在 上 面 
自由 发 表意 见 ， 但 管理 人 员 可 以 对 恶性 留言 进行 删除 、 修 改 等 。 
其 详细 制作 的 步骤 如 下 : 


步 又 014 打开 静态 页 面 index.php， 然 后 在 “现在 时 间 是 : ”后 面 加 一 个 PHP 代 码 : 
<?php 
echo date("Y-m-d h:i:s"); 
?> 


得 到 系统 当前 时 间 ， 为 文字 “留言 ”添加 一 个 超 链接 ， 链 接 到 book.php， 效 果 如 图 7-14 所 示 。 


了 到 到- 
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步 又 024 单 击 “ 代 码 ” 标 签 ， 切 换 到 代码 窗口 ， 设 置 一 个 记录 集 查 询 ; 


<?php 
$sql=mysqli query($conn,"select count(*) as total from gbook"); 
// 建 立 统计 有 记录 集 总 数 查询 
$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 和 集 
$total=$info['total']; 
// 定 义 变量 $total 值 为 记录 集 的 总 数 
if($total==0) 
{ 
echo "本 系统 暂 无 任何 留言 !"; 


} 
7/ 如果 记录 总 数 为 0 则 显示 无 数据 


else 


{ 
让 


<?php 
$pagesize=5; 
// 设 置 每 页 显示 5 条 记录 
if ($total<=$pagesize){ 
$pagecount=1; 
// 定 义 $pagecount 初 始 变 量 为 1 页 
} 
if(($total%$pagesize) !=0){ 
$pagecount=intval ($total/$pagesize)+1; 
// 取 页 面 统计 总 数 为 整数 
Jelse{ 
$pagecount=$total/$pagesize; 


} 
if((@ $_GET['page'])==""){ 
Spage=17 
// 如 果 总 数 小 于 5 则 页 码 显 示 为 1 页 
}else{ 
$page=intval ($_GET['page']); 
// 如 果 大 于 5 条 则 显示 实际 的 总 数 
} 


$sqll=mysqli query($conn,"select * from gbook where passid=0 order by ID asc 
limit ".($page-1)*$pagesize.",$pagesize "); 
// 从 gbook 数 据 表 按 条 件 为 passid 为 0， 同 时 按 ID 升 序 排序 查询 出 所 有 数据 
while(S$infol=mysqli_fetch_array(S$Ssql1) ) 
// 使 用 mysqli_fetch_array 查 询 所 有 记录 和 集 ， 并 定义 为 $infol 
六 


当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字 段 值 为 0 的 记录 时 ， 表 示 此 留言 已 经 通过 
管理 员 的 审核 ， 如 图 7-15 所 示 。 
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DW za 有 9 som 有 了 PH ED 9 EC nen 








图 7-15 输入 SQL 语句 
步骤 034 完成 记录 集 的 查询 , 然后 将 此 字段 插入 至 index.php 网 页 的 适当 位 置 , 如 图 7-16 所 示 。 


雷 ovampowmidocaooookyrdexphp 
全 En 


会 员 登 录 和 


1 舍 外 古 


5 



























0 国 


vd a 


图 7-16 绑 定 字段 
步 又 044 在 “管理 回复 ”单元 格 中 ， 根 据 数据 表 中 的 回复 字段 reply 是 否 为 空 ， 来 判断 管理 
者 是 否 访问 过 。 如 果 该 字段 为 空 ， 则 显示 “对 不 起 ， 暂 无 回复 ! ”字样 信息 ; 如 果 该 字段 不 为 空 ， 
则 表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 
步 野 054 在 “代码 ”视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 ! ” 字 
样 ， 并 加 入 代码 ， 如 图 7-17 所 示 。 


| 曾 bvemppweaecnobaovindemp 


ma 





图 7-17 加 入 代码 
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<?php echo $infol['reply'];?> 
<?php 

if($infol['reply']= empty($infol['reply'])) { 
echo "对 不 起 ， 暂 无 回复 ! ";} 

// 如 果 reply 字 段 为 空 则 显示 

else { 


// 如 果 不 为 空 则 显示 以 下 的 内 容 
?> 


管理 员 在 <?php echo $infol['redate'];?> 回 复 。 
<?php 
} 
> 


步骤 064 由 于 index.php 页 面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数 据 ,， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 并 要 加 入 “记录 集 导 航 条 ”， 
实现 的 代码 如 下 : 


<td> 共 有 留言 
<?php 
echo $total;// 显 示 总 页 数 
?> 
&nbsp; 条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ， 
&nbsp; 第 &nbsp;<?php echo S$page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;// 打 印 总 页 码 数 ?>&nbsp; 页 : 
<?php 
if($page>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
> 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a>/ 
<a href="index.php?id=<?php echo $id;?>gamp;page=<?php echo $page-1;?>" title=" 
前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 
} 
if($pagecount<=4){ 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 
for ($i=1;$i<=$pagecount; $i++) { 
?> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
} 
}else{ 
for ($i=1; $i<=4; $i++) { 
全 六 : 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 
<a href="index.php?page=<?php echo S$page-1;?>" title=" 后 一 页 "><font face= 
"webdings"> 8 </font></a> <a href="index.php?id=<?php echo $id;?>&amp;page=<?php 
echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<2php 2> 
</td> 


步骤 07 留言 簿 管理 系统 的 首页 index.php 设 计 完 成 。 打 开 浏 览 器 ， 在 地 址 栏 中 输入 
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http://127.0.0.1/gbook/ index.php， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 如 
图 7-18 所 示 。 














和 1 -= 
er ae 从 让 i 


你 的 位 轩 一 在 经 禄 言 ， 现 在 时 目 暴 : 2017-03-07 08:43:38 




























































































EEEEIEEEE 。,., 
用 户 名 : 肝 国 二 ma 三 
儿 加 果 人 有 什么 问 基 要 冯 的 活 ， 清单 击 钞 计 给 和 各 言 ， 志 位 第 一 时 间 给 委 和 页。 
.5 | 
a al ETF EE 
1 用语 由 育 | 日 1237.0.0. 1 印 和 去 ， 入 言 内 下 + 
es [ 再 是 -的 内 这 
[eas: |re, ¥Ea: 
| - = 
| i 3 TTEETTE 
了 | 有 ann [Fiano 1 ri 
有 i ela PT 
i | 管 刘 回复 : | 同意 管理 员 存 2017-02-18 回 夏 。 





图 7-18 ”留言 簿 管理 系统 主页 测试 效果 图 


7.3.2 ”留言 页 面 


本 小 节 将 要 实现 访问 者 在 线 留言 功能 ， 通 过 INSERT INTO 命 令 实现 “插入 记录 ”功能 ， 即 将 
访问 者 填写 的 内 容 插 入 到 数据 表 gbook 中 。 

制作 步骤 如 下 : 

步 野 014 执行 菜单 栏 “文件 ” 一“ 新建” 命令 打开 “新 建文 档 ” 对 话 框 ， 创 建新 页 面 ， 执 
行 菜单 栏 “ 文 件 ” 一 “另存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 保存 为 book.php。 

步骤 02 和 、 供 访问 者 留言 的 静态 页 面 book.php 与 主页 面 index.php 大 体 一 致 ,页面 效果 如 图 7-19 
所 示 。 


| 芒 piwamppintdocs\gbocl\book php Be 








| | 二、 
民 > 


wa ED 74x32 ~ 贺 
图 7-19 设计 的 页 面 效 果 
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步骤 034 人 在 留言 簿 表单 内 部 ， 分 别 执行 三 次 “插入 记录 ”一 “表单 ”一 “隐藏 区 域 ”命令 ， 
插入 三 个 隐藏 区 域 ,选中 其 中 一 个 隐藏 区 域 ， 将 其 命名 为 IP， 并 在 属性 面板 中 对 其 赋值 ， 如 图 7-20 
所 示 。 


<input name="IP" type="hidden" id="IP" value="<?php echo $_SERVER['REMOTE 
ADDR'];?>" /> 
// 自 动 取得 用 户 的 TP 地 址 





值 (Y) | echo $_SERVER[ REMDTE_ADDR' ];? 咎 化 





图 7-20 设 定 IP 值 
步骤 044 再 选择 另外 一 个 隐藏 区 域 并 命名 为 date， 并 在 “ 值 ”文本 框 中 输入 获取 系统 时 间 的 
代码 ， 如 图 7-21 所 示 。 


<input name="date" type="hidden" id="date" value="<?php 
echo date("Y-m-d"); 





Pm 
// 获 取 系 统 即时 时 间 
尾 性 
局 隐藏 区域 
|date 值 WW) <?phpeche。 date( Y-m-d ):?> 多 


图 7-21 获取 时 间 


步 最 054 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid、“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 
时 生成 的 passid 值 为 0， 管 理 者 可 以 根据 这 个 值 进行 判断 ， 方 便 后 面 的 管理 ， 如 图 7-22 所 示 。 





NI 隐藏 区 域 
passid 值 (WY) 0 > 


图 7-22 设置 passid 值 为 0 


步骤 064 选择 <form> 标 签 ， 加 入 跳 转 到 booksave.php 页 面 进行 “插入 记录 ”的 操作 ， 
booksave.php 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

include ("conn.php"); 

$subject=$ POST['subject']; 

$content=$_POST['content']; 

$date=$_POST['date']; 

$IP=$_POST[ EA lt 

$passid=$_POST['passid']; 
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mysqli query($conn,"insert into gbook (subject,content,date,IP,passid) 
values ('$subject','$content','$date','S$IP','$passid')"); 

echo "<script>alert (' 添 加 留言 成 功 !') ;history.back();</script>"; 

全 


完成 后 的 设置 如 图 7-23 所 示 。 


丛 pvampp\htdocsgboolbooksavephp -Ox | 
DD -mm 了 | 
国 此 页 面 可 能 具有 仅 可 由 服务 器 








iv 


2v 





@ rm -中 | 加 | 


图 7-23 “插入 记录 ”文档 编辑 效果 图 
步 又 07 4 回 到 网 页 设计 编辑 页 面 ， 完 成 页 面 book:php 插 入 记录 的 设置 。 


步 又 08 人 有 些 访问 者 进入 留言 页 面 book.php 后 , 不 填 任何 数据 就 直接 把 表单 送出 ， 这 样 数据 
库 中 就 会 自动 生成 一 笔 空白 数据 ， 为 了 阻止 这 种 现象 发 生 ， 须 加 入 “检查 表单 ”的 行为 。 具 体操 作 
是 在 book.php 的 标签 检测 区 中 ， 单 击 <form1l> 这 个 标签 ， 加 入 JavaScript 验 证 功能 。 


<form method="POST" action="booksave.php" name="forml" id="forml" onSubmit= 
"return chkinput (this)"> 


步骤 094 “检查 表单 ”行为 会 根据 表单 的 内 容 来 设 定 检 查 方式 ， 留 言 者 一 定 要 填 入 标题 和 
内 容 ， 因 此 将 subject、content 这 两 个 字段 的 值 设置 为 “必需 的 ”， 这 样 就 可 完成 “检查 表单 ”的 行 
为 设 定 了 ， 实 现 的 JavaScript 语 法 如 下 : 


<script language="javascript"> 
function chkinput (form) 
if(form.subject.value=="") 
{ 
alert ("请 输入 留言 主题 !"); 
form.subject.select (); 
return (false) 7? 


if(form.content .value=="") 


alert ("请 输入 留言 内 容 !"); 
form.content .select (); 
return (false); 
} 
return (true); 
} 
</script> 
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步 野 104 完成 留言 页 面 的 设计 ， 如 图 7-24 所 示 。 


DW zep mae sam BAN Im zm0) way SOW me Fe. 0 -9 














蕊 到 和 系统 后 台 管理 功能 


留言 每 后 台 管 理 系统 可 以 使 系统 管理 员 通过 admin_login.php 页 面 进行 登录 管理 , 管理 者 登录 入 
口 页 面 的 设计 效果 如 图 7-25 所 示 。 
稚 ovwampp\htdocs\ebookadmin login php 四 
源 代码 》 conn.php Tm 





body fom ~ sforml @ 43x21 ~ 图 


图 7-25 ”系统 管理 入 口 页面 


7.4.1 管理 者 登录 


管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受到 权限 约束 。 详 细 操 作 步 骤 如 下 : 

步 又 014 执行 菜单 栏 “ 文 件 ” 一“ 新建” 命令， 创建 新 页 面 ， 输 入 网 页 标题 “管理 者 登录 ”， 
执行 菜单 “文件 ”~ “保存 ”命令 ， 在 站 点 news 文 件 夹 中 的 admin 文 件 夹 中 将 该 文档 保存 为 
admin_login.php。 

步 野 024 执行 菜单 “插入 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

步骤 034 将 光标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ”一 “表格 ”命令 ， 打 开 “ 表 格 ”对 话 
框 . 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 4; 在 “ 列 ”文本 框 中 输入 需要 插入 表格 的 列 数 2; 
在 “表格 宽度 ”文本 框 中 输入 400 像 素 ; 其 他 的 选项 保持 默认 值 。 
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步骤 044 人 。 单 击 “确定 ”按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 “属性 ” 
面板 中 设置 “对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠标 选中 第 1 行 表格 的 所 有 单元 格 ， 在 “属性 ” 面 
板 中 单 击 田 按 钮 ， 将 第 1 行 表格 合并 。 用 同样 的 方法 将 第 4 行 表格 合并 。 

步骤 05 人 在 该 表单 中 的 第 1 行 中 输入 文字 “留言 后 台 管 理 中 心 ”， 在 表格 的 第 2 行 第 1 个 单元 
格 中 输入 文字 说 明 “ 用 户 : ”， 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ” 按 钮 国 ， 插 入 单行 
文本 域 表 单 对 象 ， 定 义 文本 域名 为 username，“ 文 本 域 ” 属 性 设置 如 图 7-26 所 示 。 
属性 











号 字符 痪 度 W) | 类 型 O 单 96) OO 多 行 旭 。 @ 密 FP) 类 | 无 ~| 
(usernane | 最 多 字符 数 | 初始 值 (I) | 多 
口 大 用 四) 
口 R 普 @® 








图 7-26 输入 “用 户 ” 名 和 插入 “文本 域 ”的 设置 
步骤 06 在 第 3 行 表格 中 , 输入 文字 说 明 “密码 : ”, 在 第 3 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 
本 域 ”按钮 回 ， 插 入 单行 文本 域 ， 定 义 文本 域名 为 password， “文本 域 ”属性 设置 如 图 7-27 所 示 。 
尾 性 




















三 半 革 字符 宽度 们 | | 类 型 〇 单行 S) ” 〇 多 行 如。 @ 密 码 P) 类 (人 ) [无 了 
[password | 最 多 字符 数 | 。 初始 值 (7) | ] 多 
口 莫 用 四) 
口 R 访 人 


图 7-27 输入 “密码 ”名 和 插入 “文本 域 ” 的 设置 
步骤 D7 人 单 击 选择 第 4 行 单 元 格 ， 执 行 两 次 菜单 “插入 ”一 “表单 ”一 “按钮 ” 命令 ， 插 入 
两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 一 个 为 
“ 重 设 表 单 ” 选 项 ，“ 属 性 ”的 设置 分 别 如 图 7-28 和 图 7-29 所 示 。 








按钮 名 称 值 (7 | 提交 | 动作 图 提交 去 单 S) 口 无 咱 类 (C) | 无 ~ 














Er 口 重 设 表单 (B) 


图 7-28 设置 按钮 名 称 的 属性 1 














按 禄 名 称 值 y) 重 填 」 动作 〇 提交 表单 (5) ” 〇 无 仙 类 (C) | 无 
Subnit2 | @ 重 设 表 单 (E) 


图 7-29 设置 按钮 名 称 的 属性 2 
步 又 08 4 在 标签 栏 选 择 <form> 标 签 , 设置 跳 转 到 chkadmin.php 页 面 进行 验证 , 如 图 7-30 所 示 。 
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动作 |chkadnin php 局 目标 全 v| ”类 (C) | 元 ~ 
方法 [POST ~ 编码 类 型 v 












































图 7-30 用户 登录 的 设 定 
步骤 094 新 建立 一 个 chkadmin.php 动 态 页 面 ， 输 入 验证 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$username=$ POST['username']; 
$userpwd=$_POST['password']; 
class chkinput{ 
Var $name; 
Var $pwd; 
function chkinput ($x, $y){ 
$this->name=$x; 
$this->pwd=$y; 
上’ 
function checkinput(){ 
include ("conn.php"); 
$sql=mysqli query($conn,"select * from admin where username='".$this-> 
name."'"); 
$info=mysqli fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 管理 员 名 称 输入 错误 ! ');history. 
back();</script>"; 
exit; 
1 
else{ 
if ($info['password']==$this->pwd) 
{ 
session start(); 
$_SESSION['username']=$info['username']; 
header ("location:admin.php"); 
exit; 
1 
Slse 
echo "<script language='javascript'>alert (' 密 码 输入 错误 !') ;history. 
back(); </script>"; 
exit; 
} 
} 
} 
} 
S$obj=new chkinput (trim($username),trim($userpwd)); 
$obj->checkinput (); 
?> 


步骤 1 04 完成 后 台 管 理 入 口 页 面 admin_ login.php 的 设计 与 制作 。 
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7.4.2 ”管理 主页 面 


台 管 理 页 面 admin.php 是 管理 者 由 登录 页 面 验证 成 功 后 所 跳 转 到 的 页 面 ， 这 个 页 面 提供 删除 
和 编辑 留言 的 功能 ， 效 果 如 图 7-31 所 示 。 


| 二 360 1 《< [和 一口 Xx 
所 |C 人 | 个 四 http://127.0.0.11gboowadminphp -en 


| LO |Osmas 回 后 SS 至 








人 | 
2 


您 的 位 置 : 管理 主页 面 

ph: 
编号 。 主题 月 理 卫 
上 留言 主题 一 禄 言 主 吴 一 的 内 容 127.0.0.1 网 除 / 加 
2 留言 主题 二 贸 言 主 是 二 的 内 容 129.0.112 113 。 W 除 / 加 


4 币 试 的 窗 言 主题 测试 留言 的 内 容 127.0.0.1 网 除 / 加 
共有 留言 3 条 ， 每 页 显示 5 条 ， 第 1 而 / 共 1 














图 7-31 “管理 页 面 ”的 设计 效果 
操作 步骤 如 下 : 
步 又 014 admin.php 页 面 的 动态 程序 查询 部 分 功能 和 index.php 是 相同 的 ， 在 这 里 不 作 说 明 ， 
不 同 之 处 是 加 入 访问 的 限制 和 两 个 功能 的 跳 转 操作 ， 制 作 后 的 页 面 效果 如 图 7-32 所 示 。 


曙 pvemppwmtdocsoboceadminphp -Ox 
ED moo a 


a 
«oy % 
fy A had 
Tr bd > > 
-二 “Php 留言 半 理 订 统 


a 























body tabe ft UM tbe r HH te ft HH a 74x32 ~ 轩 





图 7-32 ”后台 登录 成 功 页 面 
步 又 024 单 击 页 面 中 的 “回复 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 
览 文 件 ”图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 reply.php， 如 图 7-33 所 示 。 
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国运 s 文 件 x | 
个 国 « xampp > htdocs » gbook > v 叫 。 半 雪 'gbook” p 


组 如 ”新 建立 件 去 有 E 











属 creatve CloudF” 全 区 xB 
PE 国 date 2017/2/16 21:01 
aoes 2017/2/1621:01 | 
EL 3 Imin.php 2017/2/18 15:59 | 
国 视 页 sadmin loginphp 2017/21181103 。 PHP 文 件 
国 田 片 至 bookphp 2017121181052 。 PHP 文 件 
国 xm booksavephp 2017/21181038 PHP 文件 
时 全 chkadmin.php 2017/2151642 。 PHP 文 件 
亚 connphp 2017/211621:49 。 PHP 文 件 
小三 2011/7/281536 
于 2017/2/18 
大 本 地 寿 (C) 
一 So 、. 本 
HE 于: 文档 加 





图 7-33 ”选择 链接 文件 
步骤 034 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 。 将 参数 名 称 命名 为 ID ，<a 





href="reply.php?1D=<?php echo $infol['TD']; ?>"> 回 复 </a>， 值 设置 如 图 7-34 所 示 。 





属性 至 
Gi 机 st(F) 无 v] nie 习 B 7 得 中 所 妆 4 中 9 
了 的 | 无 ~ 希拉 ( repyphp?yp=<?php echo .~ 由 白 有 加 ~ 









单元 格 水平 中。 默认 ~ (Ww) 不 换行 (0) 口 、 背 景 需 色 (6) 厂 J| CC ni 
站 要 m 赋 A ~ 高 (H) 本 是 (9 口 


图 7-34 设置 超 链接 值 
步骤 044 选取 编辑 页 面 中 的 “删除 ”二 字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 











击 “ 浏 览 文 件 ” 图标 , 在 弹出 的 对 话 框 中 选择 用 来 显示 对 一 些 非法 留言 进行 删除 的 页 面 delbook.php， 
并 设置 传递 ID 参数 ， 如 图 7-35 所 示 。 


国运 文人 
个 由 «< xampp > htdocs > gbook > Y 书 。 理 过 gbook" 只 

组 引 ”新 建立 件 志 EmeO 
局 creative coudF 人 ER 
2017/21162101 





三 OneDrive 
2017/211621:01 。 文 (4 夫 
EL 2017/211815:59 。 PHP 文件 
国 视 需 admin loginphp 2017/211811:03 。 PHP 文件 
加 图片 bookphp 2017/2/1810:52 。 PHP 文 件 
国 放 本 $$ booksave.php 2017/21181038 。 PHP 文件 


亚 chkadminphp 2017/21151642 。 PHp 文件 
2017/2/1621:49 。 PHp 文 件 
201V71281536 PHP 文件 
2017/2118953 。。 PHP 文件 
201171281522 。 PHP 文 件 














文件 (NJ: |delbookphp ~] [WD 
E= | 
图 7-35 设置 “删除 ”的 链接 


步 最 054 设置 超级 链接 要 附带 的 URL 参 数 的 名 称 与 值 。 将 参数 名 称 命名 为 ID，<a 
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href="delbook.php?ID=<?php echo $infol[TID']; ?>"> 删 除 </a>， 值 设置 如 图 7-36 所 示 。 








层 性 二 
Fm 本 加 无 类 (天 BI 党 昌 和 举 闪 本 ) 
县 css DD 元 抽 接 旧 dalbookphpzp=<zphp ec- ~ 国名 目标 (G) = 
天。 单元 格 水平 四 黑 认 ~ 存 W T 筑 行 (0) 口 背景 颜色 (5) 三 Cn 

ED 











共和 直人 默认 ~ 高 m 标题 回 口 
图 7-36 设置 超 链接 值 


步骤 064 回 到 编辑 页 面 ， 增 加 限制 对 页 面 的 访问 功能 ， 设置 如 果 访问 被 拒绝 ， 则 转 到 
admin_ login.php 页 面 。 
<?php 
require once('conn.php'); 
session start (); 
if(@ $_SESSION['username']=="") 
{ 
echo "<script>alert (' 您 还 没有 登录 ， 
请 先 登录 ! ') ;window.1location.href='admin login.php';</script>"; 
exit; 
. 


?> 


完成 了 后 台 管理 页 面 admin.php 的 制作 。 


7.4.3 回复 留言 页 面 





回复 留言 的 功能 主要 通过 reply.php 页 面 对 用 户 留言 进行 回复 , 实现 的 方法 是 将 数据 库 的 相应 字 
段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 填写 内 容 ， 单 击 “ 回 复 ”按钮 ， 可 以 将 回复 内 容 更 新 到 
gbook 数 据 表 中 ， 页 面 效果 如 图 7-37 所 示 。 
LE 









隐 
naga me 

| 
wm 





您 要 回身 多 言 的 ID 是 号: 
三 言 H 间 : 
EeP: 
入 杆 用: 


Es 


BRE: | re 


body bbe £ YH bbe s YH gn smee 74232 ~ 区 


图 7-37 回复 留言 页 面 
回复 留言 页 面 动 态 功能 的 实现 步骤 如 下 : 





步 又 014 创建 reply.php 页 面 , 设置 一 个 动态 记录 集 查 询 ， 设 置 “ 利 选 ”的 方法 为 


: ID=URL 
参数 ID。 
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<?php 

$ID=@ $_GET['ID']; 

$sql=mysqli query($conn,"select * from gbook where ID="'".$ID."'"); 
$info=mysqli fetch array($sql); 


?> 
步 又 024 绑 定 记录 集 后 ， 再 将 绑 定 字段 插入 至 reply.php 网 页 的 适当 位 置 ， 如 图 7-38 所 示 。 
备 bowampp\htdocsgbockvepy php i 
np 


会 员 登 录 位置 -回复 留言 。、、 现 丰 B9d 间 是: 时 . 





|: [<9php echo infof e 
: [<?php echo $infol’] 
:| <?php echo $infol”s 


四 加 


> 


74x32 ~ | 加 


图 7-38 在 页 面 插入 绑 定 字段 
步骤 034 在 本 页 面 中 添加 两 个 隐藏 区 域 ， 一 个 为 redate, 用 来 设 定 回复 时 间 ， 赋 值 等 于 <?php 
echo date("Y-m-d");?>; 另外 一 个 是 passid， 用 来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 就 自动 
通过 审核 ， 如 图 7-39 所 示 。 
屋 性 





NI 隐藏 区 域 
[edate 值 G) | <?phpecho date(Ym-d):?> | 交 


-| 
Nl 隐藏 区 域 
值 (Y) 0 多 


passid 


图 7-39 ”设置 “隐藏 区 域 ”两 个 字段 的 属性 


步骤 044 新建 replysave.php 动 态 页 面 ,用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 ， 这 里 
要 特别 注意 的 只 是 更 新 回复 的 内 容 和 时 间 ， 其 他 的 字段 保持 不 变 ， 实 现 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$ID=$_POST['ID']; 
$reply=$_POST['reply']; 
$redate=$_ POST['redate']; 
mysqli_ query($conn,"update gbook set reply="'$reply',redate='$redate' where 
id="'$ID'"); 
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echo "<script>alert (' 修 改 成 功 !') ;</script>"; 
header ("location:admin.php"); 
?> 


这 样 就 完成 回复 留言 页 面 的 设置 。 





7.4.4 删除 留言 页 面 


删除 留言 页 面 为 delbook.php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 ， 实 现 的 代码 
如 下 : 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 

<?php 

session_ start (); 

include ("conn.php"); 

$ID=$_GET['ID']; 

mysqli query($conn,"delete from gbook where ID='$1ID'"); 

header ("location:admin.php"); 

?> 


这 样 就 完成 删除 留言 页 面 的 设置 。 
蕊 2 留言 簿 系统 测试 


留言 簿 系统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 了 留言 者 的 IP 
采集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 要 测试 留言 功能 的 执行 情况 。 





7.5.1 前 台 留 言 测试 


具体 的 前 台 留 言 测试 步骤 如 下 : 
步 又 014 打开 浏览 器 , 在 地 址 栏 中 输入 http:/127.0.0.1/gbook/, 打开 index.php 文 件 ， 如 图 7-40 所 示 。 





日 a= + 已 忆 


,rd 


2 





PS 更 站 :nr 
富商 = 生 


名 昌 人 和 什么 间 生 要 要 训 注 内 活 ， 庄 半 册 加 





各 吉 ， 攻 们 二 笑 一 时 问好 作 闪 豆 



























































1 

醒 

项 
mmo 国 
(nunwe) 900 加 











图 7-40 首页 效果 
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步 又 024 单 击 “留言 ”起 链接， 就 可 以 进入 留言 页 面 bookphp， 如 图 7-41 所 示 。 





PE 3 








EE 
避 全 说 口 hearl2700113 ph EE 
Da [Dsmae + [和 


SEE :2017-03.07 
舍 回 言 夭 
和 和 的 访问 ， 大 下 他人 类 9 香 史 1 
合计 主 画 + 测试 的 品评 三 是 区 
品读 及 音 | 测试 请 言 的 内 容 











EEE 而 “号 力也 下 亲 反 








图 7-41 留言 页 面 效 果 图 
步 又 034 开始 检测 留言 簿 功能 ， 在 “留言 主题 ” 栏 中 填写 “测试 的 留言 主题 ”， 在 “留言 
内 容 ” 栏 中 填写 “测试 留言 的 内 容 ”。 填 写 完 毕 后 ， 单 击 “ 提 交 ” 按 钮 ， 此 时 打开 index.php 页 面 ， 
可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 图 7-42 所 示 。 


日 su + 
名 日 全 有 什么 同 过 要 训 洒 的 湖 ， 请 间 击 留 和 入， 大 科 守 沪 一 时 卫 坟 作家 页 





D5 EE 


1 Bans: 


ema: Feri Bar: 























CE RS 
A 人 
2 wiih TY 

















四。 | 二 员 在 zh17-0z-10 四 下 








[EE 
[Ean [FO127.0.0. 1 
客户 电 话 : nl 

从 :DtD-4n7e | 


联系 人 : 厄 % 。 联系 我 们 
































图 7-42 向 数据 表 中 添加 的 数据 


7.5.2 ”后 台 管 理 测试 
台 管 理 在 留言 短 管 理 系统 中 起 着 很 重要 的 作用 ， 制 作 完成 后 也 要 进行 测试 ， 操 作 步 骤 如 下 : 


步 又 014 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/gbook/admin_login.php ， 打 开 
admin_login.php 文 件 ， 如 图 7-43 所 示 。 在 网 页 表单 对 象 的 文本 框 及 密码 框 中 输入 用 户 名 及 密码 ， 输 


入 完毕 后 单 击 “ 提 交 ” 按 钮 
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苔 360 去 全 测 沉 藉 8.1 
E © 全 | 合 加 http://127.0.0.1/gbook/admin login.phF 登 乡 v 
Db | © [Dames 口 sa x [sl BS 
留言 后 台 管 理 中 心 
户 [|_| 
密码: 
提交 | | 重要 











图 7-43 后 台 管理 入 口 


步 又 024 如 果 在 上 一 步 中 填写 的 登录 信息 是 错误 的 ， 则 浏览 器 就 会 提示 相关 的 错误 信息 ， 
如 果 输入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin.php 页 面 ， 如 图 7-44 所 示 。 





[Bre a 


|[€ je€ ©@ vm © hp//127.001/9booWadminphp EE 
Ip © Os | 加 zea “|+ [=] 


人 位 置 : 公 尖 主页 过 


全 gps 
用 号 主题 
1 
2 
4 列 民 院 留 言 王 是 





pe 网 north 
.了 “FHP 车 记过 尖 护 “ 





clo x 


Ps 


A ™ 2 

留言 主 量 一 的 内 窜 EXT 8 / 加 页 
留言 主题 二 间 内 容 129.0.412.413 。 网 / 克昌 
ME 入 罗 守 0.0.0.1 9 7 罗 具 


共有 和 言 3 杂 , 多 各 不 条 ， 第 | 页 / 甘 1 页 + 








图 7-44 打开 的 留言 管理 页 面 


步骤 034 单 击 “删除 ” 超 链接 ， 进 入 删除 页 面 delbook.php， 并 自动 将 该 留言 信息 删除 。 删 
除 留 言 后 返回 留言 管理 页 面 admin.php。 
步骤 044 在 留言 管理 页 面 单 击 “ 回 复 ” 超 链接 ， 则 进入 回复 页 面 reply.php， 如 图 7-45 所 示 。 


EE mh [1 =i x 
全 全 罗 Mrp//127.0.0.1/gb h =4 Fv 
DO Dem | asss + G5 
ir 艺 .PHP 留言 冤 理 系统 一 一 了 
ass -Beis rsa oo 
mpst PE | 志 amges 
下 所 Rsth59 
提交 | 重 轩 








本 





图 7-45 打开 的 回复 页 面 


第 7 章 ”全程 实例 五 ， 留 言 簿 管理 系统 


步骤 054 当 填 写 回复 内 容 “ 回 复 测试 ”， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回复 留言 。 


本 实例 制作 的 留言 德 管理 系 统 在 功能 上 相对 还 是 比较 简单 的 ， 读 者 如 果 在 实际 开发 中 需要 进 
行 深入 的 开发 ， 可 以 在 此 基础 上 做 一 些 变 化 ， 使 制作 的 留言 簿 能 够 更 加 人 性 化 些 。 
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第 章 


全 程 实例 六 : 网 站 论坛 管理 系统 


论坛 管理 系统 的 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 允 许 用 户 使 用 终端 程序 ， 通 过 
Internet 来 进行 连接 ， 执 行 用 户 消息 之 间 的 交互 功能 ; 支持 用 户 建 贴 、 回 复 、 搜 索 、 查 看 等 功能 。 
本 章 将 学 习 使 用 PHP 语 言 实现 论坛 管理 系统 的 开发 方法 ， 主 要 设计 网 站 论坛 管理 系统 的 首页 ， 用 
户 可 以 在 这 里 发 布 讨论 的 主题 , 并 且 也 可 以 回复 主题 , 版 主 可 以 对 自己 的 栏目 或 版 块 进行 新 增 、 修 
改 或 者 删除 等 操作 。 


论坛 管理 系统 的 规划 设计 

建立 论坛 管理 系统 的 数据 库 

新 增 主题 、 删 除 主 题 、 回 复 主 题 的 实现 方法 
论坛 系统 后 台 管 理 功 能 的 开发 
掌握 在 Dreamweaver 中 纯 手 写 PHP 代 码 的 技巧 
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医 世 国 论坛 管理 系统 的 规划 


论坛 管理 系统 是 基于 各 大 网 站 对 论坛 的 建设 和 管理 需求 而 建立 的 交互 系统 ， 主 要 实现 管理 员 
对 论坛 版 块 和 帖子 进行 管理 。 论 坛 管理 系统 的 开发 是 比较 复杂 的 ， 需 要 经 过 前 期 的 系统 规划 。 











8.1.1 页 面 设计 规划 


在 本 地 站 点 上 建立 站 点 文件 夹 bbs， 将 要 制作 的 系统 文件 如 图 8-1 所 示 。 


看 | 日 是 *|bos oo x 
EN : ss © 
和 自 sXe 
-人 周到 写 和 到 ES 和 奸 0 
su a ss 各 i 条 mn 


关 雪 

,je » FD > ampp » Nidcce » bbe 
二 中村 5 | 
局 catve coud pes 


本 OneDrive 
时 km 











图 8-1 站 点 规划 文件 
本 章 要 开发 的 BBS 论坛 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 所 示 。 
表 8-1 BBS 论坛 系统 网 页 设计 表 









































页 面 名 称 功能 

显示 主题 和 回复 情况 的 页 面 
contentphp 主要 显示 讨论 主题 的 回复 内 容 页 面 
bbs_add.php 增加 讨论 主题 的 页 面 
bbs_add_save.php 实现 主题 增加 的 动态 页 面 
admin login.php 管理 者 登录 入 口 页 面 
admin.php 对 论坛 进行 管理 页 面 
chkadmin.php 管理 者 登录 验证 页 面 
del title.php 删除 讨论 主题 的 页 面 
upd title.php 修改 讨论 主题 的 页 面 
upd title save.php 保存 修改 主题 动态 页 面 
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8.1.2 页面 美工 设计 


论坛 系统 的 界面 要 求 简洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 提高 论坛 的 加 
载 速 度 。 这 里 要 制作 的 首页 和 详细 内 容 页 面 效 果 如 图 8-2 和 图 8-3 所 示 。 








| EB 350 人 N61 [和 Xx 
€ CI 人 | 全 本 hh 127.0.0.1 BF v 
Db | © | DER [3 证 3 

PHP 论 坛 管理 系统 。“ | 论坛 首页 | 发 表 主 题 | 回复 主题 | 后 台 管理 


从 






论坛 讨论 主题 刚 表 : 


心情 忠言 主题 
六 论 主题 一 


Be peam- 























图 8-2 首页 的 美工 效果 


B21 Wx 
«IGIO 安 日 127.0.0.1 Fv 
Db © Dans svare 显 -于 =) 
PHP 论 坛 贸 理 系 统 。 论坛 首页 | 发 青 是 | 回 复 主题 ”| 后 台 管 理 上 

的 


讨论 主题 ; 讨论 主题 一 ES .EiED 


8 村 : 讨论 主 三 一 入 内 宙 


Ai as 大 tf 从 主页 了 加 














国 时 人 : at ETTETETEED 
ET 


图 8-3 详细 内 容 页 面 效果 


医 汪 论坛 管理 系统 数据 库 


制作 论坛 管理 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 定 ， 这 里 要 设计 用 于 讨论 主题 的 信息 
表 bbs_main, 用 于 回复 内 容 的 信息 表 bbs_ref, 最 后 还 需要 建立 一 个 管理 员 进 行 管理 的 信息 表 admin。 























8.2.1 数据 库 设 计 


首先 建立 一 个 bbs 数 据 库 ， 并 在 里 面 建立 管理 员 管理 信息 表 admin、 讨 论 主题 信息 表 bbs_main 
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和 回复 主题 信息 表 bbs_ref， 这 三 个 数据 表 作为 任何 数据 的 查询 、 新 增 、 修 改 与 删除 的 后 端 支持 。 
制作 的 步骤 如 下 : 
步 又 014 在 phpMyAdmin 中 建立 数据 库 bbs， 单 击 忆 将 命令 ， 打 开本 地 的 “数据 库 ”管理 页 
面 ， 在“ 新建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 bbs， 单 击 后 面 的 数据 库 类 型 下 拉 按 钮 ， 在 弹出 
的 下 拉 列 表 框 中 选择 utf8_general ci 选项 ， 单 击 “ 创 建 ”按钮 ， 返 回 “ 常 规 设置 ”页 面 ， 在 数据 库 
列表 中 就 已 经 建立 了 bbs 的 数据 库 ， 如 图 8-4 所 示 。 












本 360 夫 全 浊 这 村 81 有 
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phpMyAdmin 
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= 性 直 愉 要 
Lai 检 宣 汉阳 
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图 84 开始 建 数 据 表 


步骤 02 人 单 击 左边 的 bbs 数 据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
admin、bbs_main 以 及 bbs_ref， 即 创建 3 个 数据 表 ， 如 图 8-5 所 示 。 


[ET Bm 


OO 人 昌 127001 osv 
Do Dns 0 0 be prow + eo 
phpMyAdmin 上 






责 日 逢 天 遇 3 和 衣 HN 






1 
3 要。 全 计 mee 








Er 





局 TIN het urinary 
ET 








[i sn 1 
图 8-5 创建 3 个 数据 表 


步骤 034 、bbs_main 是 用 于 存储 论坛 的 主题 表 , 输入 数据 名 并 设置 相关 数据 ( 如 图 8-6 所 示 ) ， 
对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 bbs_main 的 字段 结构 如 表 8-2 所 示 。 





表 8-2 ”讨论 主题 bbs_main 字 段 结构 表 
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图 8-6 bbs_main 数据 表 


步骤 044 回复 主题 信息 表 bbs re 人 字段 采用 如 表 8-3 所 示 的 结构 。 设计 后 的 数据 表 如 图 8-7 所 


表 8-3 ”回复 主题 bbs_re 停 段 结 构 表 


| bsminm |m ln | 
[beD lm |ant | 
20 


[wo | 
[brftonent le | | 
20 


bbs_ ref email Varchar 20 
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8-7 “bbs_ref 数据 表 


步骤 054 最 后 设计 用 于 后 台 登 录 管理 的 admin 数 据 表 ， 字 段 采 用 如 表 8-4 所 示 的 结构 。 设计 
后 的 数据 表 如 图 8-8 所 示 。 


表 8-4 ”管理 员 admin 字 段 结构 表 
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8.2.2 ”论坛 管理 系统 站 点 


图 8-8 后 台 管理 admin 表 
数据 库 创建 完毕 后 , 在 后 台 管理 数据 表 admin 里 输入 用 户 名 和 密码 ,以 方便 后 面 登录 查询 使 用 。 


在 Dreamweaver CC 2017 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 主 要 的 设置 如 表 8-5 所 示 。 
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表 8-5 ”站 点 设置 的 基本 参数 


D:\xampp\htdocs\bbs 


D:xampp\htdocs\ 


网 站 测试 地 址 http://127.0.0.1/bbs/ 
MySQL 服 务 器 地 址 | D:xamppmysqlvdata\bbs 





root / 空 





数据 库 名 称 
创建 bbs 站 点 的 具体 操作 步骤 如 下 : 


步 又 014 首先 在 D:\xampp\htdocs 路 径 下 (如 图 8-9 所 示 ) 建立 bbs 文 件 夹 ， 本 章 所 有 建立 的 网 
页 文件 都 将 放 在 该 文件 夹 下 。 








| CELLEDLL LILI LLL 


图 8-9 建立 站 点 文件 夹 bbs 


步骤 02 和 、 运 行 Dreamweaver CC 2017， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 8-10 所 示 。 


僻 理 站 点 x 

















图 8-10 “管理 站 点 ”对 话 框 
步骤 034 对 话 框 的 上 边 是 站 点 列表 框 , 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 方 的 “新 
建 ”按钮 打开 “站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 8-11 所 示 的 参数 设置 。 
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Ede lh 和 芯 
ve 






您 可 以 在 上 外 为 Dresmweave 下 各 直 拓 本 地 久 伯 到 和 各 宛 > 


避 攻 
vbs 加 








图 8-11 建立 bbs 站 点 
步 野 044 单 击 列 表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [E， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 8-12 所 示 的 参数 设置 。 


FRE bbs x 
i 于 可 
cs [i 
0 
法 要 方法 ， 本 个 
用 和 如 他 天 : Diverco pte 电 


Web RE [Poor177. 0.0- bbe 


Ea CH OC | 
图 8-12 设置 “基本 ”选项 卡 
步骤 054 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 同步 
信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL 选 项 ， 表 示 是 使 用 PHP 开 发 的 网 
页 ， 其 他 的 保持 默认 值 ， 如 图 8-13 所 示 。 











MRE bbe x 
总 下 珊 
GE 
各 六 歼 加 六 全 和 沪 笠 
口疮 对 自动 和 文件 上 伟 到 人 关 
] 有 用 文件 3 能 
和 
地 子 邮 御 好 寺 ， 


i 


用 各 代 和: [FP MYS0L = 


加 将 祥 件 自动 梯 Sstad 划 务 车 
口 痉 合 动作 上 相关 文件 








Tm) CC 本 DC 〇 本 | 
图 8-13 设置 “高 级 ”选项 卡 
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步骤 06 和 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 界面 ， 选 中 “测试 ” 单 选 按钮 ， 如 图 8-14 





所 示 。 
就 点 设置 对 银 bbs x 
广告 一 一 一 您 将 在 此 位 置 选择 承 二 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
pa Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 
二 EE 地 二 这 并 ia 
+ 一 8 时 
保存 时 自动 推送 
SO ee ma 





Cw ) Cm ) 
图 8-14 设置 “服务 器 ”参数 
步骤 07 和 单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 2017 中 就 已 经 拥 
有 了 刚才 所 设置 的 站 点 bbs。 单 击 “ 完 成 "按钮 ,关闭 “管理 站 点 ”对 话 框 ,这 样 就 完成 了 在 Dreamweaver 
CC 2017 中 测试 网 站 论坛 管理 系统 网 页 的 环境 设置 。 


8.2.3 ”设置 数据 库 连接 

完成 了 站 点 的 定义 后 ， 需 要 在 用 户 系 统 网 站 与 数据 库 之 间 设置 连接 ， 网 站 与 数据 库 的 连接 设 
置 如 下 : 

步 又 014 将 源 文件 bbs 文 件 包 中 的 本 章 文件 复制 到 站 点 文件 夹 下 ， 打 开 index.php 论 坛 系统 的 
首页 ， 如 图 8-15 所 示 。 


















DW xnn sud sam EAD IRm mo ers WOW son 有 Ql = 
m 雄 击 

ee DNS el _ Ne 曹 
加 [Er Eee | 
W，，PHP 论 坛 逢 理 系 统 。 | is 首页 发表 主题 ”| 问 复 主题 ”| 后 各 管理 

Pe - 本 ID 

RE 相国 天 二 了 

ee =- 
EST 二 计 面 573 盏 面 古 面 面 5 


























图 8-15 打开 网 站 首页 
步 又 024 新 建 conn ,php 数据 库 连接 文件 ， 设 置 “MySQL 服 务 器 ”名 为 localhost、“ 用 户 名 ” 
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为 root、“ 密 码 ” 为 室 、“ 连 接 名 称 ”为 bbs。 

<?php 
/ /建立 数据 库 连 接 

$conn=mysqli_ connect ("localhost", "root","","bbs"); 
// 设 置 字符 为 Ltf-8，@ 抑 制 字 符 变 量 的 声明 提醒 
@ mysqli set charset ($conn,utf8); 
@ mysqli query($conn,utf8); 
// 如 果 连 接 错 误 显 示 错误 原因 
if (mysqli connect errno($conn)) 
{ 

echo "连接 MySQL 失败 : " . mysqli connect error(); 

1 


医 玫 量 发 帖 者 页 面 


供 访问 者 使 用 的 页 面 有 显示 主题 的 页 面 index.php, 讨论 主题 页 面 contentphp 以 及 回复 讨论 页 面 
bbs_reply.php， 下 面 就 开始 这 三 个 页 面 的 制作 。 





8.3.1 论坛 首页 


论坛 系统 的 主页 面 index.php 显 示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复数 以 及 最 新 回复 
时 间 。 访 问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 理 ” 图 标 进入 管理 页 面 ， 系 
统 主页 面 index.php 的 设计 效果 如 图 8-16 所 示 。 








【TREE 本 -ox 
SD rte 
PHP 论 坛 管理 系统 。 “| 论坛 首页 | 发 表 主 题 | 。 回复 主题 ”| 后 各 管理 


给 






An 























论坛 计 公主 蜂 吉 : 和 | 生理 | 

王 

全 辽 主 是 I EX 由 问 

Dp [ 

到 = 加 加 | = 下 
prerT FH rT EE EDITL 

亚 





图 8-16 BBS 论坛 系统 主页 面 效果 图 


由 本 实例 开始 在 Dreamweaver 中 的 代码 窗口 中 实现 直接 的 PHP 的 代码 编程 ， 首 页 的 代码 如 下 ， 
在 PHP 代 码 部 分 的 功能 都 进行 了 黑体 部 分 标注 : 
<?php require once('conn.php'); ?> 
<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 论 坛 管理 系统 </title> 
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<style type="text/css"> 
<l== 
body { 
margin-top: Opx; 
background-color: #FFF; 
} 
body,td,th { 
font-family: 宋体 ; 
font-size: 12px; 
1 
.Stylel8 {color: #FFFF00} 
.style25 {font-size: 18px; font-weight: bold;} 
.STYLE26 {font-size: 16px} 
aslink 
text-decoration: none; 
color: #000000; 
} 
a:visited { 
text-decoration: none; 
color: #000000; 
} 
a:hover { 
text-decoration: none; 
color: #FF0000; 
} 
a:active { 
text-decoration: none; 
color: #000000; 
| 
.STYLE28 { 
font-size: 13px; 
color: #FFFFFF; 
} 
--> 
</style></head> 
<body> 
<table width="764" border="0" align="center" cellpadding="0" cellspacing="0"> 
i 
<td width="764"><img src="images/1 副 本 .gif" width="764" height="179" 
/></td> 
< /Er 
Str 
<td height="30"bgcolor="#FFFFFF"><table width="100%"border="0"cellpadding 
="0" cellspacing="0"> 
<tr> 
<td width="339" height="30"> 论 坛 讨论 主题 列表 : </td> 
<td width="425"><table width="100%" border="0" cellspacing="0" cellpadding 
="0"> 
< 
<td><div align="right"><a href="bbs add.php"><img src="images/postnew.gif" 
width="72" height="21" border="0" /></a>gnbsp;<a href="admin login.php"><img 
src="images/Editor.gif" width="59" height="20" border="0" /></a></div></td> 
Er 
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</table></td> 
</tr> 
</table></td> 
</tr> 
tr 
<td> 
<?php 
$sql=mysqli_ query ($conn,"select count(*) as total from bbs main"); 
// 建 立 统计 有 记录 集 总 数 查询 
$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 
$total=$info['total']; 
// 定 义 变量 $total 值 为 记录 集 的 总 数 
if($total==0) 
{ 
echo "本 系统 暂 无 任何 数据 !"; 


} 
4/ 如果 记录 总 数 为 0 则 显示 无 数据 
else 


人 
品 这 


<table width="100%" border="1l" cellpadding="0" cellspacing="0" bordercolor 
="#66CCFF" bgcolor="#FFFFFF" > 
<tr> 
<td width="5%" height="29" background="../froum/images/dow3.gif"> 心 情 
</td> 
<td width="33%"> 发 言 主题 </td> 





<td 12%"> 作者 </td> 
<td 13%"> 回复 次 数 </td> 
<td 14%"> 最 新 回复 时 间 </td> 
<td 9%"> 阅 读 </td> 
<td width="14%"> 发 布 时 间 </td> 
</tr> 
<?php 


Spagesize=207 
if ($total<=$pagesize){ 
$pagecount=1; 
} 
if(($total%$pagesize) !=0){ 
S$pagecount=intval ($total/$pagesize)+1; 


}else{ 
$pagecount=$total/$pagesize; 


} 
if((@ $ GET['page'])==""){ 
$page=1; 
Telset 
$page=intval ($_GET['page']); 
1 
$sqll=mysqli query($conn,"select * from bbs main limit ". (Spage-1)*Spagesize-. 
",$pagesize "); 
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while($infol=mysqli_fetch_array($sql1)) 
{ 


EE 
<tr> 
<td><img src="<?php echo $infol['bbs face']; ?>" alt="" name=""></td> 
<td height="40"><a href="content .php?bbs_ id=<?php echo $infol 


['bbs_ID']; ?>"><?php echo $infol['bbs title'];?></a></td> 

<td><a href="content.php?bbs id=<?php echo $infol['bbs ID']; ?>"><?php echo 
$infol['bbs name'];?></a></td> 

<?php 

$bbs main id=$infol['bbs_ID']; 

$sql2=mysqli query ($conn,"select count (bbs main id) as ReturnNum from bbs ref 
where bbs main id='$bbs main id' "); 

// 统 计 出 总 共 的 回复 数 

$info2=mysqli fetch array($sql2); 

?> 

<td><a href="content.php?bbs id=<?php echo $infol['bbs ID']; ?>"><?php echo 
$info2['ReturnNum'];?></a></td> 

<?php 

$bbs_main id=$infol['bbs_ID']; 

$sql3=mysqli query($conn,"select max(bbs ref time) as LatesTime from bbs ref 
where bbs main id='$bbs main id' "); 

// 统 计 出 最 新 的 查询 时 间 

$info3=mysqli_ fetch array($sql3); 

> 

<td><a href="content.php?bbs id=<?php echo $infol['bbs_ID']; ?>"><?php 

if($info3['LatesTime']==0) 

echo "暂时 没有 回复 !"; 
else 


echo $info3['LatesTime']; 


?></a></td> 
<td><a href="content .php?bbs_id=<?php echo $infol['bbs_ID']; ?>"><?php 
echo $infol['bbs hits'];?></a></td> 
<td><a href="content .php?bbs_id=<?php echo $infol['bbs_ID']; ?>"><?php 
echo $infol['bbs time'];?></a></td> 
</tr> 
<?Pphp 


2 
</table> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tbody> 
<tr> 
<td style="text-align: right"> 共 有 主题 
<?php 
echo $total;// 显 示 总 页 数 
?> 
条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ，&nbsp; 
第 Enbsp;<?php echo $page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo $Spagecount;// 
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打印 总 页 码 数 ?>gnbsp; 页 : 
<?php 
if ($page>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
{ 
了 > 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> / 
<a href="index.php?id=<?php echo $id;?>&amp;page=<?php echo $page-1;?>" title=" 
前 一 页 "><font face="webdings"> 7 </font></a> 


<?php 
} 
if($pagecount<=4){ 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 
for ($i=1;$i<=$pagecount; $i++) { 
TE 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
下 
}elsef{ 
for ($i=1;$i<=4;$i++) { 
pe 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 


<a href="index.php?page=<?php echo S$page-1;?>" title=" 后 一 页 "><font face= 
"webdings"> 8 </font></a> <a href="index.php?id=<?php echo $id;?>&amp;page=<?php 
echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php }?></td> 
</tr> 
</tbody> 
</table> 
<?php 
} 
区 
<table width="100%" border="0" cellpadding="0" cellspacing="0" 
bordercolor="#66CCFF" bgcolor="#FFFFFF" > 
<tr> 
<td width="100%" height="20">gnbsp;</td> 
</tr> 
<tr style="text-~align: center"> 
<td height="40" bgcolor="#4DAFFE"><span class="STYLE28">Copyright @ 
2017 www.17skill.com Inc.All rights reserved. PHP 论 坛 管理 系统 </span></td> 
elEr> 
</table></td> 
</tr> 
</table> 
</body> 
</html> 


在 index.php 页 面 中 有 两 个 连接 按钮 “管理 ”与 “发 表 话 题 ”， 设 定 其 链接 网 页 如 表 8-6 所 示 。 
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表 8-6 ”按钮 链接 的 页 面 表 





8.3.2 ”讨论 主题 


讨论 主题 内 容 页 面 contentphp 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 主题 的 详 
细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-17 所 示 。 




















雷 ox 
ui 
EN a | 丰年 到 | 和 

| 

上 EM 在 : 表 | 

Ea | 

| 

| 购 主页 四 回 页 二 | 

发 表 人 : 村 

画 

| 

| 

ns: wm | 

到 | 

| 

| 

及 加 全 也 众 页 | 

mA: 妈 | 
有 四 页 村 条 , 第 折 时 不 时 杀 ， 第 即 页 兴 哇 页 曙 ” “ 攻 嚼 轨 吨 虽 ”” 呈 如 


图 8-17 讨论 主题 内 容 页 面 设计 效果 图 
实现 该 动态 页 面 的 代码 如 下 ， 其 中 黑体 加 粗 标 记 的 为 核心 累加 的 代码 : 


<?PhP require once('conn.php'); ?> 

<?PhP 

$bbs_ID=strval($_GET['bbs id']); 

mysqli_query ($conn, "UPDATE bbs main SET bbs hits = bbs hits + 1 WHERE bbs_ID 
= In,$bbs ID."'"); 


/ /阅读 时 首先 要 将 阅读 数 增加 1， 即 bbs_hits 自 动 增加 1 
-人 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> 论 坛 管理 系统 </title> 
<style type="text/css"> 
这 二 一 
body { 
margin-top: Opx; 
1 
body,td,th { 
font-family: Times New Roman, Times, serif; 
font-size: 12px; 
} 
.Style18 {color: #FFFFOO} 
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.Style25 {font-size: l8px; font-weight: bold;} 
a:link { 
text-decoration: none; 
color: #000000; 
} 
a:visited { 
text-decoration: none; 
color: #000000; 
i 
a:hover { 
text-decoration: none; 
color: #FF0000; 
T 
a:active { 
text-decoration: none; 
color: #FF0000; 
} 
.STYLE28 { font-size: 13px; 
Color: #FFFFFF; 
. 
.STYLE29 { 
color: #990000; 
font-size: 14px; 
1 
.STYLE26 {font-size: 16px} 
--> 
</style></head> 
<body> 
<table width="764" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="764"><img src="images/1 副 本 .gif"” width="764" height="179" /> 
</td> 
RE 人 


i 
<td height="30" bgcolor="#FFFFFF"><table width="100%" border="0" 
cellspacing="0" cellpadding="0"> 
<tr> 
<td width="572" height="30"><table width="99%" height="30" border="0" 
align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF"> 
<tr> 
<?php 
$sql2=mysqli query ($conn,"select * from bbs_ main where bbs_ID=$bbs_ID "); 
$info2=mysqli fetch array($sql2); 
2> 
<td valign="middle"><span class="STYLE29"> 


讨论 主题 : <?PhP echo $info2['bbs title']; ?>&nbsp;</span></td> 
</tr> 
</table></td> 
<td width="192">gnbsp;<a href="bbs add.php"><img src="images/postnew. 
gif" width="72" height="21" /></a>g&nbsp; gnbsp; énbsp; &nbsp;<a href="admin login. 
Php"><img src="images/Editor.gif" width="59" height="20" /></a></td> 
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六 /二 > 
</table></td> 
之/E 工 > 
<tr> 
<td> 


<table width="100%" border="0" cellpadding="0" cellspacing="0" bgcolor= 





"#FFFFFF"> 
<tr> 
<td><table width="100%" border= cellpadding="0" cellspacing 
bgcolor="#FFFFFF"> 
<tr> 
<td width="168" rowspan="2" bgcolor="#FFFFFF" valign="top"><p align= 
"center">gnbsp;</p> 


<p align="center"><img src="<?php echo $info2['bbs sex']; ?>" 
alt="" width="60" height="100"></p> 
<p align="center"> 发 表 人 : <?PhpP echo $info2['bbs_name']; ?></p></td> 
<td width="588" height="120" bgcolor="#FFFFFF"> 主 题 内 容 ; <?php echo 
$info2['bbs_content']; ?></td> 
</tr> 
<tr> 
<td height="25" bgcolor="#FFFFFF">&nbsp;é&nbsp;é&nbsp;<img src= 
"images/email.gif" width="16" height="16" />&nbsp; <a href="mailto:<?php echo 
$info2['bbs_email']; ?>"> 电 子 邮 件 </a> gnbsp;<img src="images/home.gif" width="16" 
height="16" />&nbsp; <a href="http://<?php echo $info2['bbs _url']; ?>"> 主 页 
</a>gnbsp; gnbsp; <img src="images/write.gif" width="16" height="16" /><a href= 
"bbs_reply.php?bbs_ID=<?php echo $info2['bbs_ID']; ?>"> 回 复 主题 </a></td> 
</tr> 
</table></td> 
LE 


ER 
<td> 
<?php 
$sql=mysqli_query($conn,"select count(*) as total from bbs_ref where 
bbs main_ID=$bbs_ID"); 

// 建 立 统计 有 记录 集 总 数 查询 

$info=mysqli fetch array($sql); 
// 使 用 mysqli_fetch_array 获 取 所 有 记录 集 

$total=$info['total']; 
// 定 义 变量 $total 值 为 记录 集 的 总 数 

if($total==0) 

{ 

echo "本 系统 暂 无 任何 回复 !"; 

} 
// 如 果 记 录 总 数 为 0 则 显示 无 数据 

@LSe 

站 

?> 

<?php 
S$pagesize=5; 
// 设 置 每 页 显示 5 条 记录 
if ($total<=$pagesize){ 
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Spagecount=17 
// 定 义 Spagecount 初 始 变量 为 1 页 
下 
if(($total%$pagesize) !=0) { 
Spagecount=intval ($total/$pagesize)+1; 
// 取 页 面 统计 总 数 为 整数 
}elsef{ 
$pagecount=$total/$pagesize; 


3 
if((@ $ GET['page'])==""){ 
S$page=1; 
4/ 如果 总 数 小 于 5 则 页 码 显 示 为 1 页 
}elsef{ 
$page=intval ($_GET['page']); 
// 如 果 大 于 5 条 则 显示 实际 的 总 数 
1 


$sqll=mysqli query($conn,"select * from bbs_ref where bbs main ID=$bbs_ID 
limit ".($page-1)*$pagesize.", $pagesize "); 
/ /设置 bbs_ref 数 据 表 按 ID 升 序 排序 查询 出 所 有 数据 
while ($infol=mysqli fetch array($sql1)) 
// 使 用 mysqli_fetch_array 查 询 所 有 记录 集 ， 并 定义 为 $infol 


<table width="100%" border="]1" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="170" rowspan="2" bgcolor="#FFFFFF" valign="top"><p 
align="center">&nbsp;</p> 
<p align="center"><img src="<?php echo S$infol['bbs ref_ 
sex']; ?>" alt="" width="60" height="100">&nbsp;&nbsp;&nbsp; </p> 
<P align="center"> 回 复 人 : <?php echo $infol['bbs ref_ 
name']; ?></p></td> 
<td width="587" height="120" bgcolor="#FFFFFF"> 回 复 内 容 : <?php 
echo $infol['bbs_ref content']; ?></td> 
</tr> 
<tr> 
<td height="25" bgcolor="#FFFFFF">&nbsp;é&nbsp; <img src= 
"images/11.gif" width="16" height="15" />&nbsp;é&nbsp;<?php echo $infol['bbs_ ref_ 
time']; ?>gnbsp;<img src="images/email.gif" width="16" height="16" />&nbsp; 
&nbsp; gnbsp; <a href="mailto:<?php echo $infol['bbs_ref email']; ?>"> 电 子 邮 件 </a> 
&nbsp;<img src="images/home.gif" width="16" height="16" />&nbsp;<a href= 
"http://<?php echo $infol['bbs_ ref url']; ?>"> 主页 </a></td> 
</tr> 
</table> 
<?php 


> 
<table width="100%" border="0" cellspacing="0" cellpadding="0"> 
<tbody> 
<tr> 
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<td> 共 有 回复 
<?php 
echo $total;// 显 示 总 页 数 
?> 
gnbsp; 条 ， 每 页 显示 &nbsp;<?php echo $pagesize;// 打 印 每 页 显示 的 总 条 数 ; ?>&nbsp; 条 ， 
&nbsp; 第 &nbsp;<?php echo S$page;// 显 示 当 前 页 码 ; ?>&nbsp; 页 / 共 &nbsp;<?php echo 
$pagecount;// 打 印 总 页 码 数 ?>&nbsp; 页 : 
<?php 
if(Spage>=2) 
// 如 果 页 码 数 大 于 等 于 2 则 执行 下 面 程序 
?> 
<a href="content .php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
/ <a href="content.php?id=<?php echo $id;?>&amp;page=<?php echo S$page-1;?>" 
title=" 前 一 页 "><font face="webdings"> 7 </font></a> 


<?php 
} 
if ($pagecount<=4) { 
// 如 果 页 码 数 小 于 等 于 4 执行 下 面 程序 
for ($i=1;$i<=$pagecount; $i++) { 
ri 
<a href="content.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
} 
}else{ 
for ($i=1; $i<=4;$i++) { 
2 
<a href="content .php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 


<a href="content.php?page=<?php echo S$page-1;?>" title=" 后 一 页 "><font 
face="webdings"> 8 </font></a> <a href="content .php?id=<?php echo $id;?>&amp;page= 
<?php echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php }?></td> 
</tr> 
</tbody> 
</table></td> 
</tr> 
</table> 
<?Pphp 
?> 
</td> 
</Er> 
</table> 
<table width="764" align="center" cellpadding="0" cellspacing="0" bgcolor= 
"#FFFFFF"> 
<tr> 
<td width="749" height="1">&nbsp;</td> 
</Er> 
<tr> 
<td height="40" bgcolor="#4DAFFE"><p style="text-align: center"><span 
class="STYLE28"> Copyright @ 2017 www.l17skill.com Inc.All rights reserved. PHP 
论坛 管理 系统 </span></p> 
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</ta> 
</tr> 

</table> 
</body> 
</html> 


说 明 : 

(1) 选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “ 属 性 ”面板 中 的 “链接 ”文本 框 后 面 
的 “浏览 文件 ”按钮 国 ， 打开“ 选择 文件 ”对 话 框 ， 在 该 对 话 框 中 选中 “数据 源 ” 单 选 按钮 ， 然 
后 在 “ 域 ? 列 表 框 中 选择 “记录 集 (detail) ”组 中 的 bbs_email 字 段 , 并 且 在 URL 链 接 前 面 加 上 “mailto: ”， 
如 图 8-18 所 示 。 














属性 
CF HE 格式 (F) 无 ~ 标题 中 

怒 css IO 无 目标 (G) 3 

加 可 单 元 格 。 水平 思 默认 ~ 宽 (Ww) 不 换行 (0) 口 ”背景 颜色 (G) 全 ,| sFFFFFF ( 页面 属 性 
时 站 放 委 直 (T) 器 人 ~v 高 H) 25 要 回 口 











图 8-18 ”设置 主题 栏 中 的 email 的 链接 
(2) 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “ 属 性 ”面板 中 的 “链接 ”文本 框 后 面 的 “浏览 
文件 ”按钮 国 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选中 “数据 源 ” 单 选 按钮 ， 然 后 在 “ 域 ” 
列表 框 中 选择 “记录 集 (detail) ”组 中 的 bbs_url 字 段 ， 并 且 在 URL 链 接 前 面 加 上 “http:/”， 如 图 
8-19 所 示 。 











属性 

《>HIML 格式 (F) 无 ~ 类 (无 小 BJ 党 早生 站 本 mn 

盈 css B00 | 元 ~ 负 入 (0 http//<3php echo $infoz[.，~ 图 自 。” 刀 |(9) ~ 

台 加 单元 格 水平 加 默认 ~ 宽 (W) 不 换行 (0) 口 ”背景 颜色 (G) 全 ,| sFFFFFF ( 页 面 属性 
el 放 委 直 (m) 默认 ~ 高 ”25 ”本 可口 











图 8-19 ”设置 主题 栏 中 的 url 链接 
(3) 在 content.php 页 面 中 有 两 个 链接 图 标 “ 管 理 ” 与 “发 表 话 题 ”， 必 须 设 定 其 链接 网 页 ， 
如 表 8-7 所 示 。 


表 8-7 ”按钮 与 链接 页 面 表 





(4) 在 BBS 论 坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 , 当 访 问 者 点 击 标题 进入 查看 内 容 时 ， 
阅读 统计 数目 就 要 增加 一 次 。 其 主要 的 方法 是 更 新 数据 表 bbs_main 里 的 bbs_hits 字 段 来 实现 。 实 现 
的 方法 很 简单 ， 在 代码 加 入 如 下 更 新 的 SQL 语 句 : 
01.UPDATE bbs main  // 更 新 bbs_main 数 据 表 


02.SET bbs_hits = bbs_hits+1 // 设 置 bbs_main 数 据 表 中 的 bbs_hits 中 字段 自动 加 1 
03.WHERE bbs ID = '".$bbs_ID."'  // bbs_ID 的 值 等 于 $bbs_ID 变 量 中 的 值 
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8.3.3 ”新 增 讨论 


新 增 讨 论 主题 页 面 bbs_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs_main 数 据 表 中 ， 
页 面 设计 如 图 8-20 所 示 。 
































| 确定 提交 | 重 作 二 写 | 
图 8-20 新 增 讨论 主题 页 面 效果 图 
详细 操作 步骤 如 下 : 
步 又 014 在 bbs_add.php 页 面 设计 中 ， 表 单 form1l 中 文本 域 和 文本 区 域 设置 如 表 8-8 所 示 。 这 
里 要 注意 “性 别 形象 ”和 “心情 ”的 单 选 按钮 都 要 在 属性 面板 中 定义 其 值 。 


表 8-8 ”表单 form1 中 的 文本 域 和 文本 区 域 设置 方法 表 








步骤 02 ”创建 bbs_add_save.php 页 面 ， 具 体 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

include ("conn.php"); 

$bbs title=$ POST['bbs title']; 

$bbs_name=$ POST['bbs name']; 
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$bbs_sex=$_ POST['bbs sex']; 

$bbs_face=$ POST['bbs face']; 

$bbs email=$ POST['bbs email']; 

$bbs url=$ POST['bbs url']; 

$bbs_content=$_ POST['bbs content']; 

$bbs time=$ POST['bbs time']; 

$bbs_hits=$ POST['bbs hits']; 

mysqli query($conn, "insert into bbs main (bbs title, bbs name, bbs_sex, 
bbs_face,bbs email,zbbs url,bbs_ content,bbs time,bbs hits) values ( '$bbs title', 
'$bbs_name','$bbs_ sex','$bbs face','$bbs email','$bbs url','$bbs content','$bb 
s_ time','$bbs hits')"); 

echo "<script>alert (' 添 加 论坛 主题 成 功 !') ;history.back();</script>"; 

| 


步 又 034 按 下 F12 键 至 浏览 器 测试 一 下 。 首先 打开 bbs_add.php 页 面 再 填写 表单 ， 填 写 表单 资 
料 如 图 8-21 所 示 。 





EE x 
ET 了 于 了 127001 EE 


b | © [Dsms [eb [eb + G2 






it 三 


了 和 


ERI TEER 
emeen 
Team 























EE 














图 8-21 填写 资料 


步骤 044 完成 资料 的 填写 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs_main 数 据 表 中 。 
页 面 将 返回 到 BBS 讨论 系统 主页 面 index.php ( 如 图 8-22 所 示 ) ， 表 示 发 布 新 主题 成 功 。 





CE EE 3 
EO mo/7001 HF 
DO Dem wwe 占 jessase 于 -到 - 


PHP 论 坛 填 理 系统 。 “| it5 攻 页 1 发 表 主题 | 回复 主题 ”| 后 台 管 表 




















lr 2 国生 理 | 
了 陆 表 i 
加 aaa- 本 Pre pr 
则 Hezs- be ee 
B= | aa wa 























图 8-22 发 表 新 主题 成 功 
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8.3.4 回复 讨论 


回复 讨论 主题 页 面 bbs_reply.php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 , 回复 主题 是 将 表单 中 
填写 的 数据 插入 到 bbs_re 人 f 激 据 表 中 ， 页 面 设计 效果 如 图 8-23 所 示 。 


全 camppwdccaoorpos epy pm -ox 


























图 8-23 回复 讨论 主题 页 面 设计 
步 又 014 由 于 在 讨论 主题 内 容 页 面 contentphp 中 ， 设 定 会 有 传递 参数 bbs ID ( 主题 编号 ) 传 
递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs_main ID 的 隐藏 域 中 。 在 页 面 上 插入 
一 个 隐藏 域 ， 并 命名 为 bbs_main_ ID， 定义 其 值 ， 如 图 8-24 所 示 。 





NN] 
[bbs_main_ID | 值 (Y) |<?php echo $bbs_nain_ID;?> 多 
图 8-24 设置 隐藏 域 bbs_main_ID 的 值 


步 又 024 然后 单 击 | 代码 标签 ， 切 换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 一 行 : 
<?php 
$bbs_main ID=strval($_GET['bbs_ID']); 
?> 


插入 后 如 图 8-25 所 示 。 


国 bvarepwecocrnbacwesrepwphp -Ox 





区 


图 8-25 插入 接收 变量 的 程序 
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步骤 034 再 插入 一 个 隐藏 字段 bbs_ ref time， 绑 定 为 当时 的 时 间 : 
<?php 
echo date("Y-m-d"); 
人 

属性 面板 的 设置 如 图 8-26 所 示 。 


属性 


Name bbs_ref_time Value <?php edho datef 经 
Hidden 


图 8-26 设置 隐藏 区 域 值 
步骤 044 创建 bbs reply_save.php 编 辑 页 面 ， 编 程 实现 bbs_reply.php 页 面 插入 记录 的 设计 。 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$bbs_main ID=$_POST['bbs main _ID']; 
$bbs_ref name=$_ POST['bbs ref name']; 
$bbs_ref sex=$_POST['bbs ref sex']; 
$bbs_ref email=$ POST['bbs ref email']; 
$bbs_ref url=$_POST['bbs _ ref url']; 
$bbs_ref content=$_POST['bbs ref content']; 
$bbs_ref time=$ POST['bbs ref time']; 
mysqli query($conn, "insert into bbs ref (bbs main ID， bbs_ ref name, 
bbs_ref_ sex,bbs ref email,bbs ref url,bbs_ ref content,bbs ref time) values 
('$bbs main ID','$bbs ref name','$bbs ref sex','$bbs ref email','$bbs ref url' 
1'$bbs_ref content','$bbs ref time')"); 
echo "<script>alert(' 回 复 主 题 成 功 !');window.location.href='index.php'; 
</script>"? 
?> 


步 最 054 按 下 F12 键 至 浏览 器 测试 。 首 先 打 开 首 页 面 ， 选 择 其 中 任 一 个 讨论 主题 ， 进 入 
content.php 页 面 ， 在 content.php 页 面 单 击 “ 回 复 主 题 ” 转 到 回复 讨论 主题 bbs_reply.php 页 面 ， 在 
bbs_reply.php 页 面 填 写 表 单 ， 填 写 表单 资料 如 图 8-27 所 示 。 


EC 全 Mpa00 OFv 
Dp © Da EP + 已 > 
PHP 论 坛 填 理 系 统 。 | 汉 =# | 发表 主题 ”| 刁 复 是 | 后 各 管理 
ind 





Fi 



































图 8-27 填写 表单 资料 
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步骤 064 完成 资料 的 填写 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs_ref 数 据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index.php， 在 单 击 主题 后 可 以 看 到 回复 ， 如 图 8-28 所 示 ， 表 





示 回 复 主 题 成 功 。 
[下 cal Ix 
《jC 全 全 器 127.0.0.1/bbs/conte OF 
Db © | Oss | Biswas + 已 3 
讨论 主题 : 测试 三 Ec 轴 管 理 






































pasha mh 台 管 理 比较 重要 , 访问 者 在 回复 主题 时 回复 一 些 非法 或 者 不 文明 的 信息 时 ， 
管理 员 可 以 通过 后 台 对 这 些 信息 进行 删除 。 





8.4.1 版 主 登录 
由 于 管理 页 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受 到 权限 管理 ， 可 以 利用 管理 员 账号 和 管理 
密码 来 判断 是 否 有 此 用 户 ， 设 计 如 图 8-29 所 示 。 


从 ovampp\htdocsbbsvadmin login php 所 本 大 
RD bb: 了 








body 502xl42 ~ 图 
图 8-29 “BBS 论坛 系统 后 台 管 理 登录 页 面 ”设计 
步 双 01 人 新 建立 一 个 chkadmin.php 动 态 页 面 ， 输 入 验证 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 


248 


第 8 章 “全程 实 例 六 : 网 站 论坛 管理 系统 





<?php 
include ("conn.php"); 
$username=$_POST['username']; 
$userpwd=$_POST['password']; 
class chkinput{ 
Var $name; 
Var $pwd; 
function chkinput ($x, $y){ 
$this->name=$x; 
Sthis->pwd=Sy7 
} 
function checkinput (){ 
include ("conn.php"); 
$sql=mysqli query($conn,"select * from admin where username='".$this-> 
name."'"); 
$info=mysqli fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 管理 员 名 称 输入 错误 ! ');history. 
back()r</ooript>™ 
exit; 
} 
else{ 
if($info['password']==$this->pwd) 
session start (); 
$_SESSION['username']=$info['username']; 
header ("location:admin.php"); 
exit; 
} 
else { 
echo "<script language='javascript'>alert (' 密 码 输入 错误 !') ;history. 
back(); </script>"; 
exit; 
} 
} 
} 
} 
S$obj=new chkinput (trim($username),trim($userpwd)); 
$obj->checkinput (); 
2 


步骤 02、 完成 后 台 管理 入 口 页 面 admin_ login.php 的 设计 与 制作 。 


8.4.2 版 主管 理 


BBS 论 坛 管理 系统 的 后 台 版 主管 理 页面 是 版 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 .这 个 页 
面 主要 为 版 主 提供 对 数据 进行 新 增 、 修 改 、 删 除 等 操作 。 后 台 版 主管 理 页 面 admin.php 的 内 容 设 计 
与 BBS 论 坛 系统 主页 面 index.php 大 致 相同 , 不 同 的 是 加 入 可 以 转 到 所 编辑 页 面 的 链接 ,页面 效果 如 
图 8-30 所 示 。 
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便 vamppwadocapbsedmmphp -Ox 
bd 


PHP 论 坛 管 理 系 统 。 “| 论坛 首页 | 发 表 主题 | 回复 主题 | 后 台 管 理 


































nd 
这 二 计 记 主 才 3: : 
ee A 
全 肌 二 Rx 3 网 Hp 二 [Sx 内 
加 图 下 站 B @ 
和 
画 


8-30 后台 版 主管 理 页 面 的 设计 


步骤 014 在 后 台 版 主管 理 页 面 admin.php 中 ， 动 态 显示 部 分 和 index.php 是 一 样 的 ， 所 以 可 以 
直接 将 index.php 另 存 为 admin.php 页 面 ， 然 后 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 每 个 讨论 主题 
后 面 都 各 有 一 个 “修改 ”按钮 和 “删除 ”按钮 ， 它 们 分 别 是 用 来 修改 和 删除 某 个 讨论 主题 的 ， 但 不 
是 在 这 个 页 面 执行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 进行 相应 的 操作 。 


步 又 024 单 击 admin.php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 
del_title.php?bbs_ID=<?php echo $infol['bbs_ID'"]; ?>， 如 图 8-31 所 示 。 
| 层 性 


加 2 Sre images/dele.gif b= (无 SD] 宽 (W 16 px 
| 抽 扩 (0 hos$nfollbbsJD];?> 加 和 白 。 纺 放 闪 守卫 OA 高 16 px 
4 四) 目标 办 ~ 
号 现 [2] 


图 8-31 设置 “链接 ”属性 


步骤 034 单 击 admin.php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 
upd_title.php?bbs_ID=<?php echo $infol['bbs_ID"]; ?>， 如 图 8-32 所 示 。 





层 性 

[ee Src images/write.gif b= (无 忆 宽 [W) 16 px 
请 。 负 说 (hos$nfol[bbsJD1;?> 加 白 。 纺 9 认命 卫 寺 OA 高 16 mx 
才 图 (M) 目标 () 水 
园 了 号 br 原始 二 


图 8-32 设置 “链接 ”属性 


8.4.3 ”删除 讨论 


“链接 ”为 


Lm] 


如 


《 


删除 讨论 页 面 del title.php 的 功能 不 只 是 要 删除 所 指定 的 主题 ， 还 要 将 跟 此 主题 相关 的 回复 留 


言 从 资料 表 bbs_ref 中 删除 。 
步骤 01 详细 代码 如 下 : 


<?php require once('conn.php'); ?> 
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<?php 


// 从 bbs_main 表 中 删除 讨论 主题 
$bbs_ID=strval($ GET['bbs ID']); 
echo $bbs_ID; 


mysqli query ($conn,"delete from bbs main where bbs_ ID='$bbs ID'"); 

// 从 bbs_ref 表 中 删除 回复 主题 

$bbs main ID=strval($ GET['bbs_ID']); 

echo $bbs main ID; 

mysqli query($conn,"delete from bbs_ ref where bbs main ID='$bbs_ ID'"); 


echo "<script>alert(' 删 除 主题 成 功 !');window.location.href='index.php'; 
</script>"; 


?> 


步 又 024 完成 删除 讨论 页 面 的 设置 。 


8.4.4 修改 讨论 


修改 讨论 主题 页 面 upd_title.php 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs_main 数 据 表 中 ， 页 面 设 
计 如 图 8-33 所 示 。 
| 伴 ovwamppwtdocs\bbsvwupd tite pho 


对 多 con oh 
PHP 论 坛 管理 系统 。 “| 论坛 首页 | 发 表 主题 | 回复 主题 | 后 台 管 理 


























图 8-33 ”修改 讨论 主题 页 面 
步 又 01 和 创建 upd_title_save.php 动 态 页 面 ， 编 写 程序 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$bbs_ID=$_POST['bbs_ID']; 
$bbs_ title=$ POST['bbs title']; 
$bbs_content=$_POST['bbs content']; 
mysqli_query ($conn, "update bbs main set bbs title='$bbs title',bbs_ content= 
'$bbs_content' where bbs_ID='$bbs ID'"); 


echo "<script>alert (' 修 改 成 功 !') ;</script>"; 
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header ("location:admin.php"); 
2> 


步 又 024 完成 修改 讨论 主题 页 面 的 设置 。 


本 实例 到 这 一 步骤 就 已 经 开发 完成 ， 读 者 通过 学 习 可 以 掌握 网 站 论坛 管理 系统 的 开发 方法 。 
在 实际 的 网 站 开发 应 用 中 , 可 以 结合 本 实例 的 一 些 技巧 开发 出 功能 更 强大 , 需求 更 多 的 大 型 网 站 论 
坛 管理 系统 。 
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第 章 


全 程 实例 七 : 莫 怒 电子 商城 前 合 


网 上 购物 系统 通常 拥有 产品 发 布 功 能 、 订 单 处 理 功 能 、 购 物 车 等 动态 功能 。 管 理 者 登录 后 台 
管理 ， 即 可 进行 商品 维护 和 订单 处 理 操作 。 从 技术 角度 来 说 主要 是 通过 “购物 车 ”就 可 以 实现 电子 
商务 功能 。 网 络 商城 是 比较 庞大 的 系统 ， 它 必须 拥有 会 员 系统 、 查 询 系统 、 购 物流 程 、 会 员 服务 等 
功能 模块 , 这 些 系统 通过 用 户 身份 的 验证 统一 进行 使 用 , 从 技术 角度 上 来 分 析 难点 就 在 于 数据 库 中 
各 系统 数据 表 的 关联 。 本 章 主要 介绍 使 用 PHP 进 行 网 上 购物 系统 前 台 开发 的 方法 ， 将 系统 地 介绍 
翡翠 电子 商城 的 前 台 设 计 ， 数 据 库 的 规划 以 及 常用 的 几 个 功能 模块 前 台 的 开发 。 


本 章 的 学 习 重 点 : 

@ 翡 洗 电子 商城 的 系统 规划 
@ 数据 库 的 设计 

@ 首页 动态 功能 开发 

@ 会 员 管 理 系统 功能 开发 
@ 新 闻 系 统 的 开发 

@ 产品 的 定购 功能 开发 

@ 购物 车 功能 的 开发 


PHP 7.0 + MySQL 网 站 开发 全 程 实 例 


医 芭 国 翡 以 电子 高 城 系统 规划 


为 了 能 系统 地 介绍 使 用 PHP 构 建 电子 商务 网 站 的 过 程 , 本 章 将 模拟 一 个 实用 的 莫 众 电子 商城 网 
站 的 建设 过 程 来 详细 介绍 网 站 想 拥 有 一 个 网 上 购物 系统 必须 做 哪些 具体 工作 ,在 进行 大 型 系统 网 站 
开发 之 前 首先 要 做 好 开发 前 的 系统 规划 ， 方 便 程 序 员 进 行 整 个 网 站 的 开发 与 建设 。 


9.1.1 电子 商城 系统 功能 


B2C 电 子 商城 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 , 让 访问 者 在 网 络 上 购物 。 网 上 
购物 以 及 网 上 商店 的 出 现 , 避免 了 挑选 商品 的 烦琐 过 程 , 让 人 们 的 购物 过 程 变 得 轻松 、 快捷、 方便 ， 
很 适合 现代 人 快 节奏 的 生活 ; 同时 又 能 有 效 地 控制 “商场 ”运营 的 成 本 , 开辟 了 一 个 新 的 销售 渠道 。 
本 实例 是 使 用 PHP+MySQL 直 接 用 手写 程序 完成 的 实例 ， 完 成 的 首页 如 图 9-1 所 示 。 


EE I 
E00 mmo oFv 
b © Dm 回 子 本 大 网 站 2 Bo 
We DEWEN @ wn: 一 也 | 吉本 
首页 | 银 击 上 条 | 出入 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 可 羊 豆 击 | 多 和 革 用 户 dui 次 好 你 注册 富生 











本 网 站 主要 能 够 实现 的 功能 如 下 : 


(1) 开发 强大 的 搜索 以 及 高 级 查询 功能 ， 能 够 让 访问 者 快速 地 找到 感 兴趣 的 商品 。 

(2) 采取 会 员 制 保证 交易 的 安全 性 。 

(3) 流畅 的 会 员 购物 流程 : 浏览 商品 一 将 商品 放 入 购物 车 一 提交 订单 支付 货款 。 每 个 会 员 都 
有 自己 专用 的 购物 车 ， 可 随时 订购 自己 中 意 的 商品 ， 结 账 完成 购物 。 购 物 的 流程 是 指导 购物 车 系统 
程序 编写 的 主要 依据 。 

(4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 详 情 。 

(5) 设计 会 员 价 商品 展示 : 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 

(6) 人 性 化 的 会 员 与 网 站 留言 : 可 以 方便 会 员 和 管理 者 进行 沟通 。 

(7) 后 台 管 理 模块 : 可 以 通过 使 用 本 地 数据 库 ， 保 证 购物 订单 安全 及 时 有 效 地 进行 处 理 ， 具 
有 强大 的 统计 分 析 功 能 ， 便 于 管理 者 及 时 了 解 财务 状况 、 销 售 状况 。 
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9.1.2 ”功能 模块 需求 分 析 


将 要 构建 的 电子 商城 系统 主要 由 如 下 几 个 功能 模块 组 成 : 


(1) 前 台 网 上 销售 模块 。 指 客户 在 浏览 器 中 所 看 到 的 直接 与 店主 面对面 的 销售 程序 ， 包 括 浏 
览 商品 、 订 购 商 品 、 查 询 定购 、 购 物 车 等 功能 ， 本 实例 的 搜索 页 面 如 图 9-2 所 示 。 


CE EE 3 


CO 127.0.0.1, sv 
D 1O | Dams [asm + 已 
有。 表 妇 后 浆 
JPEYRN Oe 


GRP | EFS | DIS | PRA | Ph | UME | NF 





MM A 
Mit i | mn 
Ro i 
HW Ji | mn 





dies eenst 01 RERT eR 











图 9-2 用 户 搜索 结果 效果 
(2) 后 台数 据 录入 模块 。 前 台所 销售 商品 的 所 有 数据 ， 其 来 源 都 是 后 台所 录入 的 数据 。 后 台 


的 产品 录入 页 面 如 图 9-3 所 示 。 


P EE + C2 

















图 9-3 商品 录入 效果 图 


(3) 后 台数 据 处 理 功能 模块 。 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 ， 都 放 在 销 
售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 是 后 台数 据 处 理 模 块 的 功能 。 后 台 订 单 处 理 页 面 如 图 9-4 
所 示 。 

(4) 用 户 注册 功能 模块 。 用 户 当然 并 不 一 定 立即 就 要 买 东西 ， 可 以 先 注册 ， 任 何 时 候 都 可 以 
来 买 东西 , 用 户 注册 的 好 处 在 于 买 完 东西 后 无 须 再 输入 一 大 堆 个 人 信息 , 只 需 将 账号 和 密码 输入 就 
可 以 了 ， 会 员 注册 页 面 如 图 9-5 所 示 。 
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图 9-5 会 员 注册 页 面 


(5) 订单 号 模块 。 客 户 购买 完 商品 后 ， 系 统 会 自动 分 配 一 个 购物 号 码 给 客户 ， 以 方便 客户 随 
时 查询 账单 处 理 情况 ， 了 解 现在 货物 的 状态 。 客 户 订购 后 结算 中 心 页 面 效果 如 图 9-6 所 示 。 

















EE J60F Rs a rE HE 
€ 避 全 让 四 MPJ127001VshoF he QFv 
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Oe: | 
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RN © [ss on 
mp aaa BS 才 济 市 人 去 R 儿 新 和 。 d 计 所作 
wm Ds! Smt 0 ao 
ME: 777 i i 
EE EL 去 融和 二 全 风物 革 it: 
于 更 元» 
上 新 年 的 第 一 织 桂 
上 过 租 长 划 档 本 订 
re 
la 
图 9-6 结算 页 面 


256 


第 9 章 全 程 实例 七 : 莫 以 电子 商城 前 台 


(6) 会 员 留 言 模块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实 现 回复 的 功能 ， 真 正 做 到 处 处 
为 顾客 着 想 ， 留 言 页 面 如 图 9-7 所 示 。 


EE 





有 二 日文 

和 和 世人 人 立 吕 127.0.0.1 中 ff Fv 

ID © Orns [ED + Le] 
有 得 开 所 交 





We /DEWEN @ erm 


Bs es 
着 页 | 最新 上 有 | 接 吕 | 的 | 品 | 产品 | 用 PP 中心 | 订阅 | 移 2 夺 
D2 


RP dor min NE 
mA » bei 》 pittABE > RPS 》 KER EE 
NP 





a 
Er 
A 2S 
去] 蕊 
RR 
HR 
CT 








图 9-7 用 户 留言 页 面 


9.1.3 ”网 站 整体 规划 


在 制作 网 站 之 前 首先 要 把 设计 好 的 网 站 内 容 放 置 在 本 地 计算 机 的 硬盘 上 ， 为 了 方便 站 点 的 设 
计 及 上 传 , 设计 好 的 网 页 都 应 存储 在 一 个 目录 下 ,再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 中 应 
该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 , 然后 在 其 中 再 创建 多 个 子 文 
件 夹 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 读 者 可 以 下 载 本 书 提供 的 素材 shop 包 ， 查 看 第 9 音 
的 站 点 文档 结构 以 及 文件 夹 结构 ， 设 计 完成 的 结构 如 图 9-8 所 示 。 


BB hp 二 瑟 这 
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图 9-8 ”网 站 文件 结构 
首先 对 本 商城 的 前 台 页 面 进行 规划 设计 ， 对 需要 设计 的 页 面 功能 进行 分 析 ， 如 下 所 示 : 


@ addgouwuche.php: 添加 定购 的 商品 到 购物 车 gouwuche.php 页 面 
@ agreereg.php: 同意 注册 页 面 
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bottom.php: 网 站 底部 版 权 
changeuser.php: 用 户 注 册 信 息 更 改 页 面 
changeuserpwd.php: 更 改 登 录 密 码 页 面 
chkuser.php: 登录 身份 验证 页 面 
chkusernc.php: 检查 昵称 是 否 被 用 文件 
conn/conn.php: 数据 库 连 接 文件 
deleteall.php: 删除 用 户 处 理 页 面 
finddd.php: 订单 查询 页 面 

findpwd.php: 找 回 密码 功能 的 页 面 
serchorder.php: 查找 到 商品 显示 页 面 
function.php: 系统 调用 的 常用 函数 
gouwuche.php: 购物 车 页 面 
gouwusuan.php: 收银 台 结 算 页 面 
highsearch.php: 高 级 查找 页 面 

index.php: 网 站 购物 车 首页 

left menu.php: 用 户 及 公告 系统 
logout.php: 用 户 退 出 页 面 

lookinfo.php: 详细 商品 信息 
openfindpwd.php: 找 回 密码 回答 答案 页 面 
reg.php: 用 户 注 册 开 始 页 面 
removegwc.php: 购物 车 移 除 指定 商品 页 面 
savechangeuserpwd.php: 更 改 用 户 密 码 页 面 
savedd.php: 保存 用 户 订单 页 面 
savepj.php: 保存 商品 评价 页 面 
savereg.php: 保存 用 户 注册 信息 
saveuserleaveword.php: 保存 用 户 留 言 页面 
showdd.php: 显示 详细 订单 页 面 
showfenlei.php: 商品 分 类 显示 页 面 
gonggao.php: 显示 详细 公告 内 容 页 面 
gonggaolist.php: 公告 罗列 分 页 显示 页 面 
showhot.php: 热门 商品 页 面 
shownewpr.php: 最 新 商品 页 面 
showpp.php: 商品 销售 排行 页 面 
showpl.php: 商品 评论 分 页 显示 页 面 
showpwd.php: 用 户 找 回 的 密码 页 面 
showtuijian.php: 推荐 商品 页 面 

top.php: 网 站 顶部 导航 条 

usercenter.php: 会 员 中 心 页 面 
userleaveword.php: 发 表 留 言 页 面 
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从 上 面 的 分 析 统计 ， 该 网 站 前 台 共 由 41 个 页 面 组 成 ， 涉 及 了 动态 网 站 建设 几乎 所 有 的 动态 功 
能 开发 设计 。 


医 也 昌 系 统 数据 库 设计 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 时 需要 从 使 用 的 功能 模块 入 手 ， 可 以 分 别 创 
建 不 同名 称 的 数据 表 , 数据 表 命 名 时 也 要 与 使 用 的 功能 名 称 相配 合 , 方便 后 面相 关 页 面 设 计 制 作 时 
的 调用 ，MySQL 数 据 库 的 制作 方法 在 前 面 的 章节 中 也 介绍 过 很 多 次 ， 为 本 章节 将 要 完成 的 数据 库 
命名 为 db_shop， 在 数据 库 中 建立 8 个 不 同 的 数据 表 ， 如 图 9-9 所 示 。 


后 360 雪 宇 议 六 戎 8 < | 曾 一 口 X 
€ CC 合生 加 http//127,0.0.1/phpe OFv 
b © | DR 
phpMyAdmin | 
全 号 站 夫人 | 
近期 访问 表 收 茂 赤 






EE 
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] tbeonetxe 帘 四 3204 的 的 洁 扫 乳 扬 \ 锣 =@ M4 4 Tmo 
地 leaveverd 傅 是 05 站 区 和 条 汪 A 手 @ W4 














] tb pimgiis 请 由 536 引 的 时 扩 和 有 括 和 铬 志和 WW <| 
tb_ahangpia 请 癌 5 沪 站 二 失 革 卫 HA 缚 邢 > 加 WE 四 | 
| tine 让 回 3 匠 的 二 相 取 用 独到 2 人 HI 四 
tb_user 请 口 各 和 W559 寺 的 守 肝 所 狠 到 冤 加 $3 Inao0B uttl. 站 
四。 总 计 1 ened wst8_gemeral_ei ta 
tt 日 a 过 大 
了 可 




















图 9.9 建立 的 db_shop 数据 库 
9.2.1 设计 商城 数据 表 


数据 库 db_shop 里 面 是 根据 开发 的 网 站 的 几 大 动态 功能 来 设计 不 同 数 据 表 的 ,本 实例 需要 创建 8 
个 不 同 的 数据 表 ， 下 面 分 别 介绍 一 下 这 些 数据 表 的 功能 及 设计 的 字段 要 求 : 


(1) tb_admin 是 用 来 存储 后 台 管理 员 的 信息 表 ， 设 计 的 tb_admin 数 据 表 如 图 9-10 所 示 。 其 中 
name 是 管理 员 名 称 ，pwd 是 管理 员 密码 。 
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NOT DO 
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图 9-10 后 台 管理 信息 表 tb_admin 


(2) tb_dingdan 是 用 来 存储 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 设 计 的 tb_dingdan 数 据 表 如 图 
9-11 所 示 。 
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图 9-11 用 户 订单 表 tb_dingdan 
(3) tb_gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 设 计 的 tb_gonggao 数 据 表 如 图 9-12 所 示 。 
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图 9-12 网 站 公告 表 tb_gonggao 





(4) tb_leaveword 是 用 户 给 网 站 管理 者 留言 的 数据 表 ， 设 计 的 tb_leaveword 数 据 表 如 图 9-13 所 
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卫生 nevs 十 奉 引 











图 9-13 ”用户 留言 表 了 b leaveword 


(5) tb_pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 设 计 的 tb_pingjia 数 据 表 如 图 9-14 所 示 。 
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图 9-14 商品 用 户 评价 表 tb_pingjia 


(6) tb_shangpin 是 商品 表 ， 购 物 系 统 中 核心 的 产品 发 布 ， 定 购 时 的 结算 都 要 调用 该 数据 表 的 
内 容 ， 设 计 的 tb_shangpin 数 据 表 如 图 9-15 所 示 。 
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图 9-15 商品 表 tb_shangpin 


(7) tb_type 是 商品 的 分 类 表 ， 设 计 的 tb_type 数 据 表 如 图 9-16 所 示 。 
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图 9-16 商品 分 类 表 tb_type 
(8》tb_user 是 用 来 保存 网 站 会 员 注册 用 的 数据 表 ， 设 计 的 tb_user 数 据 表 如 图 9-17 所 示 。 
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图 9-17 网 站 用 户 信息 表 tb_user 


上 面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 间 主 要 通过 产品 的 类 别 ID 关联 ， 建 立 网 
站 所 需要 的 主要 内 容 信息 ， 都 能 存储 在 数据 库 里 面 。 


9.2.2 ”建立 网 站 本 地 站 点 


定义 站 点 的 具体 操作 步骤 如 下 : 
步骤 01 人 首先 在 D:\xampp\htdocs 路 径 下 建立 shop 文 件 夹 (如 图 9-18 所 示 ) ， 本 章 所 有 建立 的 
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了 PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 





才 位 
Croatve doud nes 


三 Oneprive 








本 v < > 
1 项目。 计 1 人 项 上 园 s 


图 9-18 建立 站 点 文件 夹 shop 


步骤 024 打开 Dreamweaver CC 2017， 执 行 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 9-19 所 示 。 


er 
DW xein wel) EM EA 工具 Im EMR(O) Waly OW wml wel wr let 








Cette 而 cas 可 三 
x 
EE 





司 旬 aa 9 国 员 
E 





CNB (3) 














图 9-19 “管理 站 点 ”对 话 框 
步骤 034 。 单 击 “新 建站 点 ”按钮 打开 “站 点 设置 对 象 ”对 话 框 ， 进 行 如 图 9-20 所 示 的 参 
数 设置 。 
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站 点 设置 对 象 shop x 
| 
WE cremener 汪汪 网 中 人 用 的 所有 六 伯 和 和 的 人; ee 
cs jb 人 
， 高 设置 
多 可 以 在 此 处 为 Dreamwezver 站 点 选择 本 地 文件 夫 和 名 称 。 
站 点 名 称 : shop 
本 地 站 点 文件 夹 : [D: Wampphtdocs shop 站 白 
而 ) wa) 














图 9-20 建立 shop 站 点 
步骤 04M 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 车 ]， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 9-21 所 示 的 参数 设置 。 


处 点 设置 对 象 shop x 
四 十 琴 
Cs 服务 器 名 称 ; shop 
高 级 设置 
连接 方法 : 本 地 / 愉 络 
服务 器 文件 夫 : D:yampphtdocs 扎 





Web URL: [http:/1127.0.0, 本 











Nema Am 




















图 9.21 “基本 ”选项 卡 设置 

步 最 054 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 界面 ， 选 中 “维护 同步 

言 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 框 中 选择 PHP MySQL， 表 示 是 使 用 PHP 开 发 的 网 页 ， 
其 他 的 保持 默认 值 ， 如 图 9-22 所 示 。 
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步 又 064 
9-23 所 示 。 

















服务 器 模型 : | PHP MySQL | 





编辑 服 


将 文件 自动 推送 到 而 二 服务 器 
口 始终 自动 保存 相关 文件 











站 点 设置 对 象 shop x 
| = 
Css 远程 服务 器 
高 级 设置 维护 同步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 自用 文件 取出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 
电子 邮件 地 址 : 
测 式 服务 器 








图 9-22 设置 “高 级 ”选项 卡 





十 一 
动 推送 


Se mon 


CE CHD CHI 








单 击 “ 保 存 ” 按 钮 ， 返 回 “服务 器 ”设置 界面 ， 再 单 击 “ 测 试 ” 单 选 按钮 ， 如 图 
站 点 设置 对 象 shop x 
人 你 在 此 位 轩 括 承 web 上 的 而 的 有 务 器 。 此 对 话 械 的 设 轩 来 和 

Er Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 

1 EE 地 lL 放 ia 现 








图 923 设置 “服务 器 ”参数 


步 又 07 4 单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CC 2017 测 试 shop 


网 站 环境 设置 。 


9.2.3 ”建立 数据 库 连 接 


数据 库 设计 之 后 ， 需 要 将 数据 库 链接 到 网 页 上 ， 这 样 网 页 才能 调用 数据 库 和 储存 相应 的 信息 。 
用 PHP 开 发 的 网 站 , 一 般 将 数据 库 连 接 的 程序 代码 文件 命名 为 conn.php。 在 站 点 文件 夹 创建 conn.php 
空白 页 面 ， 按 如 图 9-24 所 示 输 入 数据 库 连 接 服务 器 的 代码 。 
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替 pwampp\htdocsshopvconn php* -Ox 

v <?php 

$conn=mysqli_connect("localhost", "root","", "db_shop"); 

@ mysqli_set_charset ($conn,utf8); 
4 @ mysqli_query($conn,utf8); 

if (mysqli_connect_errno($conn)) 
vi 

echo "连接 MySQL 失败 : " 。 mysqli_connect_error(); 

} 


?> 


@ mvmu 


图 9-24 设置 数据 库 连接 

对 于 本 连接 的 程序 进行 如 下 说 明 : 

<?php 

$conn=mysqli connect ("localhost","root","","db shop"); 
// 设 置 数据 库 连接 ， 本 地 服务 器 ， 用 户 名 为 root， 密 码 为 空 ， 连 接 的 数据 库 为 db_shop 
@ mysqli_set_charset ($conn,utf8); 
@ mysqli query($conn,utf8); 

// 设 置 数据 库 的 字体 为 Ltf-8 

if (mysqli connect errno($conn)) 

{ 

echo "连接 MySQL 失败 : " . mysqli_connect error(); 

// 如 果 连 接 错误 调用 mysql_error () 函数 

} 

?> 


读者 使 用 时 如 果 需 要 更 改 数据 库 名 称 ,只 需要 将 该 页 面 中 的 db_shop 做 相应 的 更 改 即 可 以 实现 ， 
同时 也 要 将 用 户 名 和 密码 与 你 在 本 地 设置 的 用 户 名 和 密码 相同 。 


医改 量 首页 动态 功能 开发 


对 于 一 个 电子 商城 系统 来 说 ， 需 要 一 个 主页 面 为 用 户 提供 注册 、 搜 索 需 要 定购 的 商品 、 网 上 
浏览 商品 等 操作 。 实 例 首页 index.php 主 要 嵌 套 了 fontcss、top.php、left_ menu.php、bottom.php 等 5 
个 页 面 ， 本 节 介 绍 这 些 页 面 的 设计 过 程 。 








9.3.1 创建 样式 表 


任何 网 站 如 果 想 看 上 去 美观 些 都 是 要 经 过 专业 的 网 页 布局 设计 的 ， 实 例 按 传 统 的 电子 商务 网 
站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样式 表 保 存在 css 
文件 夹 下 。 

步骤 014 运行 Dreamweaver CC 2017 软 件 ， 打 开 制 作 到 这 一 步骤 的 站 点 文件 夹 。 执 行 菜单 栏 
“文件 ”一 “新 建 ”命令 ， 打 开 “ 新 建文 档 ” 对 话 框 ， 选 择 “ 新 建文 档 ” 选 项 卡 中 “文档 类 型 ”下 
拉 列 表 框 下 的 CSS， 然 后 单 击 “ 创 建 ”按钮 创建 新 页 面 ， 如 图 9-25 所 示 。 在 网 站 css 目 录 下 新 建 一 个 
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名 为 font.css 的 网 页 并 保存 。 

















Cme IREO 





图 9-25 创建 css 文件 
步骤 D2 人。 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 
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} 


} 


} 


CURSOR: hand; 
font-style: normal 7 


inputcss { 
font-size: 9pt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
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border-color: #93BEE2 #93BEE2 #93BEE2 #93BEE2 ; 


border: lpx #93BEE2 solid; 


inputcssnull { 
font-size: 9pt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border: Opx #93BEE2 solid; 


scrollbar{ 
SCROLLBAR-FACE-COLOR: #FFDD22; 
FONT-SIZE: 9pt; 
SCROLLBAR-HIGHLIGHT-COLOR: #69BC2C; 
SCROLLBAR-SHADOW-COLOR: #69BC2C; 
SCROLLBAR-3DLIGHT-COLOR: #69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: #69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


} 

scrollbar{ 
SCROLLBAR-FACE-COLOR: #FFDD22; 
FONT-SIZE: 9pt; 
SCROLLBAR-HIGHLIGHT-COLOR: #69BC2C; 
SCROLLBAR-SHADOW-COLOR: #69BC2C; 
SCROLLBAR-3DLIGHT-COLOR: #69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: #69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


n 


// 网 页 表单 对 象 的 样式 设置 
通过 上 面 样式 文件 的 建立 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 


9.3.2 ”设计 网 站 导航 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 常情 况 1 
会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 或 者 需要 更 改 时 ， 这 个 工作 
量 就 会 变 得 很 大 ， 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开发 成 单独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调 
用 它 。 这 样 当 需 要 变更 时 ， 只 要 修改 导航 栏 这 一 个 页 面 ， 其 他 的 页 面 自动 就 全 部 更 新 了 。 实 例 创建 的 带 


下 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 型 一 点 的 可 能 
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显示 登录 用 户 名 的 导航 栏 ， 如 图 9-26 所 示 。 














感 360 祥 全 浏览 生 8.1 标 单 | 省 一 口 x 
专 |G| 合 | 食 日 127.0.0.1 BF v 
1》 | © | Dmmws 回 电子 商务 网 站 + Bo 
负 ” 攻 如 巡 衣 
‘wm WREWEN © xin: | 
首 。 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查 鹿 | 购物 车 用 户 :desi gr 欢 凶 您 注销 高 开 
图 9-26 导航 频道 
这 里 制作 的 步骤 如 下 : 


步 又 014 在 Dreamweaver CC 2017 中 执行 菜单 栏 “ 文 件 ” 一 “新 建 ”命令 ， 打开 “新 建文 档 ” 
对 话 框 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 下 的 PHP 选 项 ， 在 “布局 ”下 拉 列 表 框 
中 选择 “无 ”选项 ， 然 后 单 击 “ 创 建 ”按钮 创建 新 页 面 ， 在 网 站 根 目录 下 新 建 一 个 名 为 top.php 的 
网 页 并 保存 。 


步 又 024 再 单 击 “显示 代码 视图 ”| 代码 按钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创 
建 代码 删除 ， 然 后 加 入 如 下 代码 : 


<?php 
session start (); 
// 包 含 1 类 函数 文件 
require once('conn.php'); 
ea 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 电 子 商 务 网 站 </title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<body> 
<table width="766" border="0" align="center" cellpadding="0" cellspacing="0" 
background="images/bannerdi .gif"> 
<tr> 
<td colspan="3" valign="bottom"><table width="766" border="0" align= 
"center" cellpadding="0" cellspacing="0"> 
EE 
<td width="224" height="83">&nbsp;</td> 
<td align="right"><p>&nbsp;</p> 
<table height="20" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<form name="form" method="post" action="serchorder.php"> 
<tr> 
<td width="81" height="30" align="right">&nbsp;</td> 
<td width="500" height="30" valign="middle"><div align="left"> 
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&nbsp;<span class="style4"><img src="images/biao.gif" width="16" height="21"> 
&nbsp; 输 入 关键 词 : </span> 
<input type="text" name="name" size="25" class= 
"inputcss"style="background-color:#e8f4ff "onMouseOver="this.style.backgroundColor 
="'#£fffff'" onMouseOut="this.style.backgroundColor='#e8f4ff'"> 
<input type="hidden" name="jdcz" value="jdcz"> 
<input name="submit" type="submit" class="buttoncss" 
value=" 搜 索 "> 
<input name="button" type="button" class="buttoncss" 
onClick="javascript:window.location='highsearch.php';"” value=" 高 级 搜索 "> 
</div></td> 
</tr> 
</form> 
</table></td> 
</tr> 
</table></td> 
</tr> 
<tr> 
<td width="568" height="32" bgcolor="#FFFFFF"><a href="index.php"> 首 页 
</a>| <a href="shownewpr .php"> 最 新 上 架 </a> | <a href="showtuijian.php"> 推 荐 产品 </a> 
| <a href="showhot.php"> 热 门 产品 </a>l&nbsp;<a href="showfenlei.php"> 产 品 分 类 
</a>g&nbsp;|&nbsp;<a href="usercenter.php"> 用 户 中 心 </a>&nbsp;|&nbsp;<a href= 
"finddd .php"> 订 单 查 询 </a>&nbsp; | &nbsp;<a href="gouwuche .php"> 购 物 车 </a></td> 
<td width="121" align="center" bgcolor="#FFFFFF"> 
<?php 
if(@ $_SESSION['username'] !="''){ 
echo "用 户 :$_SESSION[username] 欢 迎 您 "; 
} 
?> 
</td> 
<td width="77" bgcolor="#FFFFFF"> 
<?php 
if(@ $_SESSION['username'] { 
echo "<a href='1logout .php'> 注 销 离 开 </a>"; 
</td> 
</tr> 
</table> 


上 述 代码 中 加 黑 部 分 为 显示 用 户 登录 和 注销 离开 的 程序 。 


步骤 034 加 入 代码 后 ， 这 时 就 会 发 现在 编辑 文档 窗口 中 ， 多 了 一 个 PHP 代 码 占 位 符 贿 ， 
如 图 9-27 所 示 。 





价 bvanppwudocoshopwopphp -Ox 


WW crmpp mtcs 了 





tooy @ zx ~ 加 


图 9-27 自动 生成 代码 占 位 符 
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步骤 044 最 后 保存 制作 的 页 面 , 按 下 F12 快 捷 键 ， 即 可 以 在 浏览 器 中 看 到 和 原来 一 样 的 导航 效果 。 


9.3.3 ”登录 和 新 闻 


left_ menu.php 页 面 中 的 “用 户 系 统 ” 和 “新 闻 公告 ”两 个 栏目 是 动态 网 站 开发 中 经 常 遇 到 的 功 
能 ,在 电子 商城 中 这 几 个 功能 也 是 必 不 可 少 的 ， 下 面 本 小 节 将 详细 介绍 这 些 功能 的 实现 办 法 ， 制 作 
步骤 如 下 : 


步 最 014 为 了 能 够 实现 页 面 的 调用 , 需要 首先 打开 数据 库 db_shop 文 件 , 然后 打开 tb_gonggao 
数据 表 ， 加 入 一 些 数据 ， 如 图 9-28 所 示 。 


[ET 














ETX 
€ OH Va Fv 
Db | © [Orme ro -BB 
phpMyAdmin ee 
所 所 刘 册 新 总机 与 3L 和 拓 和 A 所 5% 司 SA 7s 
1 党 太 间 末了 交 


捅 引 六。 无 







1 
i i He content 
i i RN O We 


rT 

这 本 利 亲 才 光 | 各 于 加 强人 诬 吐 。 11 | 
ms 3 FW O WE 1 

Ck ll [3 

Wa MO MN J 0 

We Em OW 3 


人 


EE 














步 又 024 创建 left menu.php 页 面 ， 然 后 在 <head> 代 码 之 前 ， 加 入 调用 数据 库 链 接 页 面 
conn.php 的 命令 ， 如 下 所 示 : 


<?php include("conn.php");?> 


然后 简单 地 设计 一 下 用 户 系统 和 新 闻 公 告 两 个 功能 的 显示 效果 ， 设 计 完成 后 编辑 文档 窗口 ， 
如 图 9-29 所 示 。 


入 -doceshopvek menuphp 。 - Dx 
人) -mo T 
用 户 系统 ， 

六 








图 9-29 设计 页 面 的 显示 效果 
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步骤 034 在 “用 户 系 统 ” 的 显示 界面 上 ， 是 提供 给 用 户 登 录 、 注 册 以 及 找 回 密码 的 功能 ， 
具体 的 注册 和 找 回 密码 的 功能 将 在 下 一 节 介 绍 , 这 里 重点 介绍 使 用 PHP 实 现 验证 码 随 机 调用 并 显示 
成 数字 的 功能 ， 程 序 如 下 : 
<?php 
$num=intval (mt_rand(1000, 9999)); 
// 使 用 mt_rand() 函数 调用 介 于 1000-9999 的 任意 一 个 数字 
for ($i=0; $i<4; $i++) { 
echo "<img src=images/code/".substr (strval ($num),$i,1).".gif>"; 


} 
// 调 用 images/code/ 文 件 夹 下 的 随机 字母 图 片 ， 并 显示 成 4 位 数 
?> 


该 程序 能 够 实现 如 图 9-30 所 示 的 随机 显示 图 片 验 证 码 数字 的 效果 。 
会 员 登 录 : 
会 员 : 
密码 : 
验证 : 7599 
于 光 | 新手 注册 找 回 密码 
图 9-30 运行 后 显示 验证 码 效果 


步骤 044 用 户 输入 用 户 名 和 密码 , 并 单 击 “ 提 交 ” 按 钮 后 , 就 将 输入 的 数据 传递 到 chkuser.php 
页 面 进行 登录 验证 。 代 码 如 下 : 


<form name="form2" method="post" 


action="chkuser.php" onSubmit="return 
chkuserinput (this)"> 


该 段 代码 包含 了 两 个 意思 ， 第 一 个 action="chkuser.php" 意 思 是 转 到 chkuser.php 页 面 进行 验证 ; 
第 二 个 onSubmit="return chkuserinput(this)" 意 思 是 直接 调用 JavaScript 的 chkuserinput(this) 进 行 数据 
输入 的 验证 , 即 通常 在 提交 表单 时 要 验证 一 下 输入 的 数据 是 否 为 空 ,输入 的 数据 格式 是 否 符合 要 求 ， 
调用 的 程序 如 下 : 


<script language="javascript"> 
function chkuserinput (form){ 
if(form.username.value==""){ 
alert ("请 输入 用 户 名 !") ; 
form.username.select (); 
return (false); 
}// 如 果 用 户 名 没 输入 提示 “请 输入 用 户 名 ! ” 
if (form.userpwd.value==""){ 
alert ("请 输入 用 户 密码 !") ; 
form.userpwd.select (); 
return (false); 
} // 如 果 用 户 密码 没 输入 提示 “请 输入 用 户 密码 !” 
if(form.yz.value==""){ 
alert ("请 输入 验证 码 !"); 
form.yz.select (); 
return (false); 


}// 如 果 用 户 验证 码 没有 输入 提示 “请 输入 验证 码 !” 


return (true); 
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} 
</script> 


步骤 054 在 主页 的 “新 闻 公 告 ” 显 示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 
时 能 打开 详细 页 面 ， 调 出 5 条 所 有 的 数据 并 将 所 有 的 代码 列 出 ， 说 明 如 下 : 


<table width="180" border="0" align="center" cellpadding="0" cellspacing="0"> 


Er 
<td height="5"></td> 
</tr> 
<?php 
$sql = mysqli query($conn,"SELECT * FROM tb gonggao ORDER BY time desc limit 
0, 5") ;// 按 时 间 顺 序 查 询 最 新 的 五 条 数据 
$info = mysqli fetch array($sql); 
if ($info==false){ 
D> 
<tr> 
<td height="20" align="center"> 暂 无 新 闻 公 告 !</td> 
</tr> 
<?php 


elsel{ 
do{ 
2> 
i 
<td height="20"><div align="center"> 
<table width="180" border=" 
cellpadding="0" cellspacing="0"> 


<tr> 
<td width="16" height="5"><div align="center"><img 


align="center" 





src="images/circle.gif" width="11"” height="12"></div></td> 
<td width="164" height="24"><div align="left"> <a 
href="gonggao.php?id=<?php echo $info['id'];?>"> 
<?php 
echo substr($info['title'],0,25); 
if(strlen($info['title'])>25){ 
echo ",.."; 
} 
?> 
</a> </div></td> 
A 
</table> 
</div></td> 
</tr> 
<?php 
while($info=mysqli _ fetch assoc($sql)); 
} 
2> 
</table> 


步骤 064 在 浏览 器 中 浏览 制作 的 调用 数据 ， 效 果 如 图 9-31 所 示 。 
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新 闻 公告 : 更 多 ?> 


» 新 年 的 第 一 双 圣 

» 过 腔 长 蒜 据 配 短 禄 
» 服装 行业 持续 低迷 
» 2017 春 夏 巴 黎 高 织 时 


9-31 “新 闻 公 告 ”的 效果 


如 此 就 很 容易 地 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 发 现 PHP 动 态 网 页 的 开 
发 并 不 是 很 难 ， 只 需要 掌握 简单 的 代码 即 可 以 实现 。 在 其 他 功能 页 面 的 所 有 其 他 区 域 都 是 采用 
调用 、 条 件 查询 、 绑 定 显示 、 关 闭 数 据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 


此 时 Left_meau.php 页 面 就 开发 完毕 了 ， 保 存 以 方便 其 他 页 面 嵌 套 使 用 。 


9.3.4 ”产品 的 前 台 展 示 


网 站 实现 在 线 购 物 ， 一 般 都 是 通过 用 户 自身 的 登录 、 浏 览 、 定 购 、 结 算 这 样 的 流程 来 实现 网 
上 购物 的 , 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 重要 , 实例 在 首页 上 设计 了 “推荐 产品 ”“ 最 
新 上 架 ” 以 及 “热门 产品 ”三 个 显示 区 域 ， 下 面 就 介绍 产品 展示 区 域 的 实现 方法 。 

步 桑 01 对 于 上 述 的 三 个 显示 区 域 在 使 用 程序 开发 之 前 ， 首 先 要 在 Dreamweaver CC 2017 中 
设计 好 最 终 的 网 页 效果 ， 实例 设 计 的 三 个 展示 区 域 如 图 9-32 所 示 , 每 个 区 域 显示 最 新 发 布 的 两 款 产 
品 信息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “详细 ”的 按钮 。 


LE 





图 9-32 设计 产品 展示 的 区 域 效果 
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步骤 024 三 个 区 域 的 程序 实现 的 方法 是 一 样 的 ， 只 是 按 条 件 查询 出 数据 的 结果 是 不 一 样 的 ， 
这 里 介绍 “推荐 产品 ”区 域 的 代码 实现 方法 如 下 : 
<table width="550" border="00" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="555" height="110"><table width="530" height="110" border="0" 
align="center" cellpadding="0" cellspacing="0"> 
os 
<td width="265"> 
<?php 
$sql=mysqli query($conn,"select * from tb shangpin where tuijian=1 order by 
addtime desc limit 0,1"); 
// 按 tuijian=1 的 值 调 用 数据 
$info=mysqli fetch array($sql); 
if ($info==false){ 
echo "本 站 暂 无 推荐 商品 !"; 
有 
// 如 果 没 有 数据 显示 为 "本 站 暂 无 推荐 商品 !" 
elsef{ 
Te 
<table width="270" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[ ‘tupian’ ]=="")){ 
echo " 暂 无 图 片 "; 
}// 如 果 没有 产品 图 片 则 显示 为 " 暂 无 图 片 " 
elsef 
> 
<img src="<?php echo $info[ ‘tupian’];?>" width="80" height="80" border="0"> 
<?php 
1 
?> 
</div></td> 
<td width="11" height="16">&nbsp;</td> 
<td width="124"><font color="FF6501"><img src="images/circle.gif" width="10" 
height="10">gnbsp;<?php echo $info[mingcheng];?></font></td> 
</tr> 
xt 
<td height="16">&gnbsp;</td> 
<td><font color="#000000"> 市 场 价 : </font><font color="FF6501"><?php echo 
$info[shichangjia]l;?></font></td> 
过 /> 
<EP> 
<td height="16">&nbsp;</td> 
<td><font color="#000000"> 会 员 价 : </font><font color="FF6501"><?php echo 
$info[ ‘huiyuanjia’];?></font></td> 
</tr> 
<tr> 
<td height="16">gnbsp;</td> 
<td><font color="#000000"> 剩 余数 量 : </font><font color="13589B"><?php 
if($info[ ‘shuliang’]>0) 
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echo $info[ ‘shuliang’]; 
} 
else 
‘ 
echo "已 售 完 "; 
} 
2 
</font></td> 
/Er 
Er 
<td height="30" colspan="2"><a href="lookinfo.php?id=<?php echo $info 
[‘id’];?>"><img src="images/b3.gif" width="34" height="15" border="0"></a> <a 
href="addgouwuche.php?id=<?php echo S$info[id];?>"><img src="images/bl.gif" 
width="50" height="15" border="0"></a> </td> 
/Er> 
</table> 
<?php 
} 
?> 
</td> 
<td width="265"> 
<?php 
$sql=mysqli query($conn,"select * from tb shangpin where tuijian=1 order by 
addtime desc limit 1,1"); 
$info=mysqli fetch array($sql); 
if ($info==true) 
{ 


?> 
<table width="270" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[ ‘tupian’ ]=="")){ 


echo " 暂 无 图 片 "; 
} 
else{ 
人 
<img src="<?php echo $info[ ‘tupian’];?>" width="80" height="80" border="0"> 
<?php 
} 
?> 
</div></td> 
<td width="11" height="16">&nbsp;</td> 
<td width="124"><font color="FF6501"><img src="images/circle.gif" width="10" 
height="10">gnbsp;<?php echo $info[ ‘mingcheng’];?></font></td> 
</tr> 
<tr> 
<td height="16">&nbsp7</td> 
<td><font color="#000000"> 市 场 价 : </font><font color="FF6501"><?php echo 
$info[ ‘shichangjia’];?></font></td> 
</tr> 
< 
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<td height="16">&nbsp;</td> 
<td><font color="#000000"> 会 员 价 : </font><font color="FF6501"><?php echo 
$info[ ‘huiyuanjia’];?></font></td> 

</tr> 
EE 
<td height="16">gnbsp;</td> 
<td><font color="#000000"> 剩 余数 量 : </font><font color="13589B"> 
<?php 

if($info[ ‘shuliang’]>0) 

{ 

echo $info[‘shuliang’]; 


else 


2 
</font></td> 
</tr> 
<tr> 
<td height="30" colspan="2"><a href="lookinfo.php?id=<?php echo $info 
[\id’];?>"><img src="images/b3.gif" width="34" height="15" border="0"></a> <a 
href="addgouwuche.php?id=<?php echo S$info[\id’];?>"><img src="images/bl.gif" 
width="50" height="15" border="0"></a> </td> 
</tr> 
</table> 
<?php 
} 
名 
</td> 
</tr> 
</table></td> 
SEE 
<tr> 
<td height="10" background="images/linel.gif"></td> 
/Er 
</table> 


步骤 034 按 上 述 程序 实现 的 方法 ， 将 另外 两 个 产品 展示 的 功能 也 设计 完成 ， 最 后 可 以 实现 
的 效果 如 图 9-33 所 示 。 








图 9-33 首页 的 商品 展示 效果 
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9.3.5 ”版 权 页 面 


底部 版 权 页 面 是 一 个 静态 的 页 面 ， 制 作 非常 的 简单 ， 在 Dreamweaver CC 2017 中 进行 直接 排版 
设计 即 可 ， 完 成 的 效果 如 图 9-34 所 示 。 


从 cvamppwtdocsshop\botom php SE 





738x151 ~ 加 


图 9-34 版 权 页 面 的 效果 


网 站 的 首页 制作 结束 ， 如 果 需 要 快速 建立 首页 ， 可 以 直接 参考 源 代码 shop 文 件 包 完 成 的 页 面 ， 
查看 代码 ， 可 以 方便 地 完成 电子 商城 系统 首页 的 设计 与 制作 。 


医 记 量 会 员 管理 系统 功能 


网 站 的 会 员 管理 系统 ， 在 首页 上 只 是 一 个 让 用 户 登 录 和 注册 的 窗口 。 当 输入 用 户 名 和 密码 时 ， 
单 击 “ 提 交 ” 按 钮 ， 即 转 到 chkuser.php 页 面 进 行 判断 用 户 是 否 可 以 登录 。 当 单 击 “注册 ”文字 链接 
时 ， 将 会 打开 网 站 的 会 员 注册 页 面 agreereg.php 进 行 注 册 。 单 击 “ 找 回 密码 ”文字 链接 会 弹出 找 加 
密码 的 Windows 对 话 窗口 ， 本 小 节 将 对 会 员 管理 系统 的 开发 进行 介绍 。 

















9.4.1 会 员 登 录 判 断 


会 员 在 首页 输入 用 户 名 和 密码 ， 单 击 “ 提 交 ” 按 钮 时 只 有 用 户 名 、 密 码 、 验 证 码 全 部 正确 才 
可 以 登录 成 功 ， 如 果 有 错误 就 需要 显示 相关 的 错误 信息 。 所 有 的 功能 都 要 用 PHP 进 行 分 析 判 断 ， 创 
建 一 个 空白 PHP 页 面 ， 并 命名 为 chkuser.php。 

在 该 页 面 中 加 入 如 下 的 代码 : 


<?php 
include ("conn.php"); 
// 调 用 数据 库 连接 
$username=$_POST[ ‘username’ ]; 
$userpwd=md5 ($_POST[ ‘userpwd’ ]); 
$yz=$_POST[ ‘yz’]; 
$num=$_POST[ ‘num’ ] 7 
if(strval ($yz) !=strval ($num)){ 
echo "<script>alert (' 验 证 码 输入 错误 !') ;history.go(-1);</script>"; 
exit; 
}// 如 果 验 证 码 错误 则 提示 “验证 码 输入 错误 !”， 并 且 返 回 登 录 页 面 
class chkinput{ 
Var $name; 
Var S$pwd; 
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function chkinput ($x, $y){ 
$this->name=$x; 
$this->pwd=$y; 
} 
function checkinput(){ 
include ("conn.php"); 
$sql=mysqli query($conn,"select * from tb user where name='".$this->name."'"); 
$info=mysqli fetch array($sql); 
if($info==false){ 
echo "<script language='javascript'>alert(' 不 存在 此 用 户 ! ');history. 
back();</script>"; 
exit; 
， 
// 如 果 数 据 库 里 不 存在 该 用 户 名 则 显示 “不 存在 此 用 户 ”， 并 返回 
elsef 
if($info[ ‘dongjie’ ]==1){ 
echo "<script language='javascript'>alert(' 该 用 户 已 经 被 冻结 ! 
biotory back( <script> 
exit; 


} 
// 如 果 用 户 已 经 在 后 台 冻 结 ， 则 显示 “该 用 户 已 经 被 冻结 ! ”并 且 返 回 
if(S$info[\pwd']==S$Sthis->pwd) 
1 
session start (); 
$_SESSION[ ‘username’ ]=$info[ ‘name’ ]; 
$producelist=""; 
$quatity=""; 
header ("location:index.php"); 
exit; 
} 
else { 
echo "<script language='javascript'>alert (' 密 码 输 入 错误 ! ') ;history. 
back() ;</script>"; 
exit; 


} 
// 如 果 用 户 密码 错误 ， 则 显示 “密码 输入 错误 ! ”并 且 返 回 
} 
} 
} 


S$obj=new chkinput (trim($username),trim($userpwd)); 
$obj->checkinput (); 
?> 


该 段 程序 ， 首 先 加 入 判断 验证 码 、 用 户 名 以 及 密码 是 否 正确 的 代码 ， 如 果 不 正 确 则 显示 相应 
的 错误 信息 ， 如 果 全 部 正确 则 登录 成 功 返 回 登录 的 首页 。 


9.4.2 会 员 注册 功能 


会 员 注册 的 功能 并 不 只 是 简单 的 一 个 网 页 就 能 实现 ， 它 需要 用 户 协 议 ， 判 断 用 户 是 否 同 意 注 
册 ， 写 入 数据 等 细节 的 步骤 这 里 介绍 如 下 : 
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步 又 014 单 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注册 页 面 agreereg.php， 该 页 面 制 
作 的 效果 如 图 9-35 所 示 。 该 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 一 下 网 站 管理 者 ， 为 了 避免 日 后 注册 用 
户 会 发 生 一 些 纠纷 ， 需要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 放 到 注册 信息 里 面 , 这 样 才 可 以 有 
效 地 保护 自己 的 利益 。 


从 cvemppwtdocnshopwgreeree ohp -Ox 
ED ote -careoap nbman 









用 PP 和议 


ee 人 

对 且 户 晤 有 之 雪 - 
用 户 进一步 同意 ， nnn 7 
li 
户 。 本 汪 各 和 区 自用 户 二 作 辽 有 日 外 在 用 产 与 电子 商 过 间 产 生 法 








boty a ~ 国 


图 9-35 用 户 协议 里 的 服务 条 款 


步骤 024 单机 “同意 ”按钮 后 ， 就 打开 具体 的 注册 用 户 信息 填写 内 容 页 ， 该 页 面 制作 时 也 
比较 简单 ,只 需要 以 数据 库 中 tb_user 数 据 表 的 字段 名 为 准 , 在 注册 页 面 分 别 创建 相应 的 文本 框 即 可 ， 
设计 的 页 面 如 图 9-36 所 示 。 


付 owemppwedocoshepves php -Ox 
RB) pate etree heterotp 


EE 
Vo | | 





图 9-36 用 户 注册 信息 的 页 面 


步骤 034 其 中 的 技术 难点 在 于 “查看 昵称 是 否 已 用 ”功能 ， 在 输入 用 户 昵 称 时 ， 需 要 单 击 
该 按钮 检查 数据 库 中 是 否 已 存在 该 用 户 昵称 ， 实 现 的 方法 代码 如 下 : 
<script language="javascript"> 
function chknc (nc) 
4 
window.open ("chkusernc.Php?nc="+nc "newframe", "width=200,height=10, left=500 
:top=200,menubar=no,toolbar=no, location=no, scrollbars=no, location=no"); 
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' 


// 单 独 打 开 Windows 窗 口 通 过 调用 chkusernc .php 页 面 进行 判断 
</script> 


所 以 嵌 套 的 实际 判断 的 页 面 是 chkusernc.php， 该 页 面 的 代码 如 下 : 


<?php 
$nc=trim($ GET[ ‘nc’]); 
?> 
<?php 
include ("conn.php"); 
2> 
<html> 
<head> 
<title> 
昵称 重用 检测 
</title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<table width="200" height="100" border="0" align="center" cellpadding="0" 
cellspacing="0" bgcolor="#eeeeee"> 
<tr> 
<td height="50"><div align="center"> 
<?php 
if ($nc=="" 
echo "请 输入 昵称 !"; 
} 
else 
{ 
$sql=mysqli_ query($conn,"select * from tb user where name='".$nc."'"); 
$info=mysqli _ fetch array($sql); 
if ($info==true) 
{ 
echo "对 不 起 , 该 昵称 已 被 占用 !"; 
} 
else 
{ 
echo "恭喜 , 该 昵称 没 被 占用 !"; 
} 
} 
2 
</div></td> 
</tr> 
<tr> 
<td height="50"><div align="center"><input type="button" value=" 确定 " 
class="buttoncss" onClick="window.close()"></div></td> 
=/ 
</table> 
</body> 


步骤 044 在 单 击 “ 提 交 ” 按 钮 时 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 的 JavaScript 程 序 进行 
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检查 的 代码 如 下 : 





PHP 7.0 + MySQL 网 站 开发 全 程 实例 


该 段 程序 是 验证 表单 经 常 使 用 到 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 对 于 其 他 系统 的 
开发 也 经 常 使 用 到 。 


人 在 验证 表单 没 问题 后 , 才 将 表单 的 数据 传递 到 savereg.php 页 面 进行 数据 表 的 插入 记 


录 操 作 ， 也 就 是 实质 上 的 保存 用 户 注 册 信 息 的 操作 ， 具 体 的 代码 如 下 : 





第 9 章 “全 程 实例 七 : 翡翠 电子 商城 前 台 





$tishi=$ POST['ts2°']; 
3 
else 
{ 
$tishi=$ POST['ts1']; 
S$huida=$ POST['tsda']; 
$dizhi=$_POST['dizhi']; 
$youbian=$_POST['yb']; 
$regtime=date ("Y-m-j"); 
$dongjie=0; 
$sql=mysqli query($conn,"select * from tb user where name='".$name."'"); 
$info=mysqli fetch array($sql); 
if ($info==true) 
{ 
echo "<script>alert (' 该 昵称 已 经 存在 !') ;history.back();</script>"; 
exit; 
} 
else 
1 
mysqli query ($conn,"insert into tb_user (name,pwd,dongjie,email,truename, sfzh, 
tel,qq,tishi,huida,dizhi,youbian, regtime,pwdl1) values ('$name', '$pwd', 
'$dongjie','$email','$truename','$sfzh','$tel','$qq', '$tishi','$huida','$dizhi 
','$youbian','$regtime','$pwd1')"); 
$username=$name; 
$producelist=""; 
$quatity=""; 
echo "<script>alert (' 恭 喜 ， 注 册 成 功 ! ' ) ;window.1location='index.php';</script>"; 
由 


通过 以 上 几 个 步骤 的 程序 编写 才 完成 一 个 会 员 注册 的 功能 ， 一 般 的 用 户 注册 都 是 这 样 的 一 个 
逻辑 实现 过 程 。 


9.4.3” 找 回 密码 功能 


会 员 在 使 用 过 程 中 忘记 密码 也 是 经 常 遇 到 的 事 ， 在 实例 中 单 击 “ 找 回 密码 ”文字 链接 将 打开 
相应 的 窗口 实现 找 回 密码 的 功能 ， 具 体 的 实现 步骤 如 下 : 


步骤 01 和 在 制作 的 left_ menu.php 页 面 中 加 入 Javascript 的 验证 代码 ,实现 的 功能 是 单 击 “ 找 回 
密码 ”链接 时 打开 openfindpwd.php 页 面 进行 验证 ， 代 码 如 下 : 


<script language="javascript"> 
function openfindpwd(){ 
window.open ("openfindpwd.php", "newframe","left=200,top=200,width=200,height 
=100,menubar=no,toolbar=no, location=no,scrollbars=no, location=no"); 
} 
</script> 








步 桑 02 和。 使 用 Dreamweaver CC 2017 设 计 出 找 回 密码 的 页 面 如 图 9-37 所 示 ， 只 需要 一 个 简单 
的 对 话 窗口 ， 输 入 昵称 并 进行 判断 即 可 。 


285 


PHP 7.0 + MySQL 网 站 开发 全 程 实 例 





耸 ovampp\htdocs\shop\openfindpwd php -Ox 





body 加 375x106 ~ 图 


图 9-37 找 回 密码 的 页 面 
步 野 034 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ” 按 钮 需要 进行 表单 验证 ， 判 断 是 
否 为 空 ， 如 果 不 为 空 则 指向 findpwd.php 页 面 显示 “密码 提示 ”， 输 入 提示 的 答案 ， 如 图 9-38 所 示 。 
<script language="javascript"> 


function chkinput (form) 
{ 


if(form.nc.value=="") 

{ 

alert ("请 输入 您 的 昵称 !"); 
form.nc.select (); 
return (false); 


} 


return (true) ? 
} 
</script 


由 owampp\htdocs\shop\findpwd.php 
叹 谎 fontcs ”comphp 了 





body 394xl28 ~ 图 
图 9-38 密码 提示 页 面 
步 最 044 输入 “提示 答案 ”之 后 ， 单 击 “ 确 定 ”按钮 ， 也 要 进行 表单 验证 并 转向 最 终 显示 
密码 的 页 面 showpwd.php， 验 证 的 代码 如 下 : 


<script language="javascript"> 

function chkinput (form) 
if(form.da.value=="") 

{ 

alert ( "请 输入 密码 提示 答案 !" ) 7 

form.da.select (); 

return (false); 

} 


return (true); 
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</script> 


<form name="form2" method="post" action="showpwd.php" onSubmit="return 
chkinput (this)"> 


步骤 054 showpwd.php 的 页 面 比较 简单 ， 只 需要 查询 数据 库 ， 把 符合 条 件 的 数据 显示 出 来 ， 
即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-39 所 示 。 


内 owampp\htdocsshop\showpwd php 2 
代码 》 fontcs com.php 了 





body 4ilxl28 ~ 图 


图 9-39 显示 密码 页 面 


医 攻 国 品牌 新 闻 系统 


网 站 的 “新 闻 公告 ”在 首页 及 各 个 页 面 显 示 了 标题 ， 当 单 击 相应 的 标题 时 ， 将 打开 详细 的 显 
示 内 容 页 面 gonggao.php，gonggao.php 用 于 显示 具体 的 信息 内 容 ， 当 单 击 首页 的 “更 多 >>” 文 字 链 
接 时 ， 即 可 打开 所 有 的 信息 标题 页 面 gonggaolist.php。 
9.5.1 ”信息 标题 列表 


所 有 的 信息 标题 页 面 gonggaolist.php 制 作 的 效果 ， 如 图 9-40 所 示 。 


入 ovamppwsocsshop\gonggaolstphp -Ox 


ND oppp efnenptp botonshe T 





body 7T5x35 ~ | 图 
图 9-40 所 有 新 闻 列 表 页 面 效果 
该 页 面 的 编写 程序 部 分 如 下 所 示 : 
<?php 


$sql=mysqli query($conn ,"select count(*) as total from tb gonggao"); 
$info=mysqli fetch array($sql); 
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$total=$info[ ‘total’]; 
if($total==0) 
于 
echo "本 站 暂 无 公告 !"; 
} 
// 调 用 tb_gonggao 数 据 ， 如 果 没 有 则 显示 “本 站 暂 无 公告 !” 
else 
{ 
?> 
<table width="530" border="0" align="center" cellpadding=" 
<tr bgcolor="#EEEEEE"> 
<td width="296" height="20"><div align="center"> 公 告 主题 </div></td> 
<td width="136"><div align="center"> 发 布 时 间 </div></td> 
<td width="68"><div align="center"> 查 看 内 容 </div></td> 
SEE> 
<?php 
$pagesize=20; 
if ($total<=$pagesize){ 
$pagecount=1; 
} 
if(($total%$pagesize) !=0) { 
Spagecount=intval ($total/$pagesize)+1; 





"cellspacing= 


}elsef 
$pagecount=$total/$pagesize; 


} 
if(($_GET[‘page’ ])=—=""){ 
S$page=1; 


}else{ 
$page=intval ($_GET[ ‘page’ ]); 


$sqll=mysqli query($conn ,"select * from tb gonggao order by time 
desc limit ".($page-1)*$pagesize.",$pagesize "); 

while ($infol=mysqli fetch array($sql1)) 

1 


?> 
bE 
<td height="20"><div align="left">-<?php echo $infol[‘title’];?> 
</div></td> 
<td height="20"><div align="center"><?php echo S$infol[‘time’];?> 
</div></td> 


<td height="20"><div align="center"><a href="gonggao.php?id=<?php 
echo $infol[ “id’];?>"> 查 看 </a></div></td> 
</tr> 
<?php 
} 
2> 
<tr> 
<td height="20" colspan="3"> gnbsp; 
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<div align="right"> 本 站 共有 公告 Egnbsp; 
<?php 
echo S$total; 
> 
&nbsp; 条 &nbsp; 每 页 显示 &nbsp;<?php echo $pagesize;?>&nbsp; 条 &nbsp; 第 gnbsp;<?php 
echo $page;?>&nbsp; 页 / 共 &gnbsp;<?php echo $pagecount; ?>&nbsp; 页 
<?php 
if ($page>=2) 
{ 
?> 
<a href="gonggaolist.php?page=1" title=" 首 页 "><font face="webdings"> 9 
</font></a> <a href="gonggaolist.php?id=<?php echo $id;?>&amp;page=<?php echo 
$page-1;?>"” title=" 前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 
¥ 
if(Spagecount<=4) 1{ 
for ($i=1;$i<=$pagecount; $i++) { 
?> 
<a href="gonggaolist.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
} 
}else{ 
for ($i=1; $i<=4;$i++) { 
2 
<a href="gonggaolist.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php }?> 
<a href="gonggaolist.php?page=<?php echo S$page-1;?>" title=" 后 一 页 
"><font face="webdings"> 8 </font></a> <a href="gonggaolist.php?id=<?php echo 
$id;?>&amp;page=<?php echo $pagecount;?>" title=" 尾 页 "><font face="webdings"> 
</font></a> 
<?php }?> 
</div></td> 
</tr> 
</table> 
<?php 
} 


?></td> 
Er> 
</table> 
该 页 面 的 技术 难点 在 于 新 闻 标题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 一 般 都 要 使 用 上 述 的 
分 页 显示 功能 实现 按 页 显示 记录 。 


9.5.2 ”显示 详细 内 容 


有 具体 信息 量 显示 页 面 ， 通 常 包括 显示 信息 的 标题 、 时 间 以 及 出 处 ， 制 作 的 具体 效果 如 图 9-41 
所 示 。 
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入 ovamppwtocsshop\eonggao php 
SR opp Cefnenpp 。 fmcionphp botonphe T 






首 ”页 | 最 新 上 条 | 推荐 产品 





分类 | 用 户 中 心 | 订 音 相关 | 购 和 丰 


body 75x35 ~ 图 


图 941 详细 新 闻 页 面 


该 页 面 的 编写 程序 部 分 如 下 所 示 : 

<table width="530" border="0"align="center" cellpadding="0" cellspacing="1"> 

<?php 

$id=$_GET[ “id’]; 
$sql=mysqli_ query($conn,"select * from tb gonggao where id="'".$id."'"); 
$info=mysqli fetch array($sql); 
include ("function.php"); 
?> 

<tr> 

<td width="24" height="25" bgcolor="#FFFFFF"><div align="center"> 
</div></td> 

<td width="315" bgcolor="#FFFFFF"><div align="center"> 公 告 主题 ; <?php echo 
unhtml ($info[ ‘title’]);?></div></td> 

<td width="66" bgcolor="#FFFFFF"><div align="center"> 发 布 时 间 : </div></td> 

<td width="120" bgcolor="#FFFFFF"><div align="left"><?php echo 
$info[ ‘time’];?></div></td> 

</tr> 

<tr> 

<td height="125" bgcolor="#FFFFFF"><div align="center"></div></td> 

<td height="125" colspan="3" bgcolor="#FFFFFF"><div align="left"><?php echo 
unhtml ($info[ ‘content’]);?></div></td> 

</tr> 

</table> 


通过 上 述 两 个 页 面 的 设计 ， 品 牌 新 闻 系 统 的 前 台 部 分 即 开发 完成 。 


荫 对 对 产品 的 定购 功能 


购物 车 系统 主要 由 网 上 产品 定购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 的 主要 有 
产品 显示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 ， 主 要 包括 index.php、 用 于 显示 产品 详细 信息 的 页 
面 lookinfo.php、“ 最 新 上 架 ” 频 道 页 面 shownewpr.php、“ 推 荐 产品 ”频道 页 面 showtuijian.php、“ 热 
门 产品 ”频道 页 面 showhotphp、“ 产 品 分 类 ”频道 页 面 showfenleiphp、 产 品 搜索 结果 页 面 
serchorder.php。 下 面 分 别 介绍 除了 首页 以 外 页 面 功能 的 实现 。 
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9.6.1 产品 介绍 页 面 


产品 介绍 页 面 lookinfo.php 是 用 来 显示 商品 细节 的 页 [ 面 。 细节 页 面 要 能 显示 出 商品 所 有 的 详细 
信息 ， 包 括 商 品名 称 、 商 品 产地 、 商 品 单位 、 商 品 图 片 ， 以 及 是 否 还 有 商品 放 入 购物 车 等 功能 ， 实 
例 中 我 们 还 加 入 了 “商品 评价 ”功能 。 

由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-42 所 示 的 动态 页 面 。 在 页 面 中 ， 一 个 PHP 代 码 图 标 
代表 加 入 动态 命令 实现 该 功能 。 


国 o\arepmeocnsnopvonanophn 四 


oo mde enenpio potongo T 























本 [ca 


图 9-42 商品 介绍 页 面 


该 模块 的 程序 分 析 如 下 ， 其 中 购物 车 的 实现 代码 进行 了 加 粗 说 明 。 


<?php 
$sql=mysqli_query ($conn,"select * from tb_shangpin where id=".$_GET[‘id’].""); 
$info=mysql_fetch object ($sql); 
?> 
< 
<td width="89" height="80" rowspan="4" align="center" valign="middle" bgcolor= 
"#FFFFFF"><div align="center"> 
<?php 
if ($info->tupian==""){ 
echo " 暂 无 图 片 "; 
} 
else 
{ 
| 
<a href="<?php echo $info->tupian;?>" target=" blank"><img src="<?php echo 
$info->tupian;?>"” alt=" 查 看 大 图 " width="80" height="80" border="0"></a> 
<?php 
} 
?> 
</div></td> 
<td width="92" height="20" align="left" bgcolor="#FFFFFF"><div align= 
"center"> 商 品名 称 : </div></td> 
<td width="134" bgcolor="#FFFFFF"><div align="left">g&nbsp;<?php echo 
$info->mingcheng;?></div></td> 
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<td width="100" bgcolor="#FFFFFF"><div align="center"> 入 市 时 间 : </div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">gnbsp;<?php echo 
$info->addtime;?></div></td> 

< Ar> 

> 

<td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 会 员 价 : 
</div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">g&nbsp;<?php echo $info-> 
huiyuanjia;?></div></td> 

<td width="100" bgcolor="#FFFFFF"><div align="center"> 市 场 价 : </div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">g&nbsp;<?php echo 
$info->shichangjia;?></div></td> 

</tr> 

E> 

<td height="20" align="]left" bgcolor="#FFFFFF"><div align="center"> 等 级 : 
</div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">&nbsp;<?php echo $info-> 
dengji;?></div></td> 

<td width="100" bgcolor: 

<td width="129" bgcolor= 
pinpai;?></div></td> 

</tr> 

EE 

<td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 型 号 : 
</div></td> 

<td width="134" bgcolor="#FFFFFF"><div align="left">g&nbsp;<?php echo 
$info->xinghao;?></div></td> 

<td width="100" bgcolor="#FFFFFF"><div align="center"> 数 量 : </div></td> 

<td width="129" bgcolor="#FFFFFF"><div align="left">&nbsp;<?php echo $info-> 
shuliang;?></div></td> 

</tr> 

<tr> 

<td width="89" height="69" bgcolor="#FFFFFF"><div align="center"> 商 品 简介 : 
</div></td> 

<td height="69" colspan="4" bgcolor="#FFFFFF" valign="top"><div align= 
"left"><br> 

&nbsp; gnbsp; gnbsp’; gnbsp;<?php echo $info->jianjie;?></div></td> 

</tr> 

</table></td> 

</tr> 

</table> 

<table width="530" height="20" border="0" align="center" cellpadding="0" 
cellspacing="0"> 

<tr> 

<td><div align="right"><a href="addgouwuche.php?id=<?php echo $info->id;?>"> 
放 入 购物 车 </a>snbsp;snbsp;</div></td>// 单 击 “ 放 入 购物 车 ”传递 产品 的 id 号 并 到 
addgouwuche .php 去 结算 

</tr> 

</table> 

<?php 

if($_SESSION[username] !="") 

2 





"#FFFFFF"><div align="center"> 品 牌 : </div></td> 
#FFFFFF"><div align="left">gnbsp;<?php echo $info-> 
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<form name="forml" method="post" action="savepj.php?id=<?php echo S$info-> 
id;?>" onSubmit="return chkinput (this)"> 
<table width="530" border="0" align="center" cellpadding="0" cellspacing="0"> 
六 Eee 
<td height="25" bgcolor="#EEEEEE"><div align="center" style="color: #FFFFFF"> 
<div align="left">g&nbsp;&nbsp;<span style="color: #000000"> 发 表 评 论 
</span></div> 
</div></td> 
</tr> 
<tr> 
<td height="150" bgcolor="#999999"><table width="530" border="0" align= 
"center" cellpadding="0" cellspacing="1"> 
<script language="javascript"> 
function chkinput (form) 


if(form.title.value=="" 
{ 
alert ("请 输入 评论 主题 !") ; 
form.title.select (); 
return (false); 
直 
if(form.content .value== 
{ 
alert (" 请 输入 评论 内 容 !") ; 
form.content .select() 7 
return (false); 
} 


return (true); 





"mn) 


} 
</script> 
<tr> 
<td width="80" height="25" bgcolor="#FFFFFF"><div align="center"> 评 论 主题 : 
</div></td> 
<td width="467" bgcolor="#FFFFFF"><div align="]left"> 
<input type="text" name="title" size="30" class="inputcss" style="background- 
color:#e8f4ff " onMouseOver="this.style.backgroundColor="'#ffffff'" onMouseOut= 
"this.style.backgroundColor='#e8f4ff'"> 
</div></td> 
</te> 
<Er> 
<td height="125" bgcolor="#FFFFFF"><div align="center"> 评 论 内 容 : </div></td> 
<td height="125" bgcolor="#FFFFFF"><div align="left"> 
<textarea name="content" cols="70" rows="]10" class="inputcss" style= 
"background-color:#e8f4ff " onMouseOver="this.style.backgroundColor="#ffffff'" 
onMouseOut="this.style.backgroundColor='#e8f4ff'"></textarea> 
</div></td> 
</tr> 
</table></td> 
Wr 
</table> 
<table width="530" height="25" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
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<td><div align="center"> 

<input name="submit2" type="submit" class="buttoncss" value=" 发 表 "> 

gnbsp; gnbsp; gnbsp;<a href="showpl.php?id=<?php echo $_GET[id];?>"> 查 看 该 商品 评 
论 </a></div></td> 

</tr> 

</table> 

</form> 

<?php 

} 


?> 


在 上 面 的 代码 中 ， 展 示 的 只 是 数据 的 查询 和 显示 功能 ， 核 心 功能 在 于 “发 表 评论 ”， 单 击 “ 发 
按钮 后 将 传递 到 savepj.php 页 面 保存 评价 ， 其 页 面 的 代码 如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$title=$ POST['title']; 
$content=$_POST['content']; 
$spid=$_GET['id']; 
$time=date ("Y-m-j"); 
session start(); 
$sql=mysqli query($conn,"select * from tb user where name='".$_ SESSION 
['username']."'"); 

$info=mysqli fetch array ($sql); 

$userid=$info['id']; 

mysqli_ query($conn,"insert into tb pingjia (userid, spid,title,content, 
time) values ('$userid','$spid','$title','$content','$time') "); 


echo "<script>alert (' 评 论 发 表 成 功 !') ;history.back();</script>"; 
De 


册 


9.6.2 最 新 上 架 频 道 


该 页 面 为 单 击 导航 条 中 的 “最 新 上 架 ” 链 接 后 转 到 的 页 面 shownewprphp， 主 要 是 显示 数据 库 
中 最 新 上 架 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完成 的 效果 如 图 9-43 所 示 。 


ovamocomdee: 
BD -orn 














图 9-43 最 新 上 架 的 页 面 
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代码 核心 部 分 如 下 : 


<table width="550" height="70" border="0" align="center" cellpadding="0" 


cellspacing="0"> 


<?php 
$sql=mysqli query($conn,"select * from tb shangpin order by addtime desc limit 


[oP 


// 从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info=mysqli fetch array($sql); 

if ($info==false){ 

echo "本 站 暂 无 最 新 产品 !"; 

1 

elsef{ 
dof 

?> 
<tr> 
<td width="89"rowspan="6"><div align="center"> 
<?php 

if ($info[ ‘tupian’ ]==""){ 

echo " 暂 无 图 片 !"; 

} 

else{ 

二 
<a href="lookinfo.php?id=<?php echo $info['\id' ];?>"><img border="0" src="<?php 


echo $info[ ‘tupian’];?>" width="80" height="80"></a> 


称 : 


<?php 
} 
?> 
</div></td> 
<td width="93" height="20"><div align="center" style="color: #000000"> 商 品名 
</div></td> 
<td colspan="5"><div align="left"><a href="lookinfo.php?id=<?php echo $info 


[\id’];?>"><?php echo $info[mingcheng];?></a></div></td> 


牌 : 


</tr> 

< 

<td width="93" height="20"><div align="center" style="color: #000000"> 商 品 品 
</div></td> 

<td width="101" height="20"><div align="left"><?php echo $info[ ‘pinpai’];?> 


</div></td> 


Ss 


<td width="62"><div align="center" style="color: #000000"> 商 品 型 号 ;: </div></td> 
<td colspan="3"><div align="left"><?php echo $info[‘xinghao’];?></div></td> 
= 

<tr> 

<td width="93" height="20"><div align="center" style="color: #000000"> 商 品 简 
</div></td> 

<td height="20" colspan="5"><div align="left"><?php echo $info[‘jianjie’];?> 


</div></td> 


</tr> 

<tr> 

<td height="20"><divalign="center" style="color: #000000"> 上 市 日 期 :</div></td> 
<td height="20"><div align="left"><?php echo $info[‘“addtime’];?></div></td> 
<td height="20"><divalign="center" style="color: #000000"> 剩 余数 量 : </div></td> 
<td width="69" height="20"><div align="left"><?php echo $info[\shuliang']7;?> 
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</div></td> 

<td width="63"><div align="center" style="color: #000000"> 商 品 等 级 : </div></td> 

<td width="73"><div align="left"><?php echo $info[‘dengji’];?></div></td> 

RE 

> 

<td height="20"><div align="center" style="color: #000000"> 商 场 价 : </div></td> 

<td height="20"><div align="left"><?php echo S$info[‘shichangjia’];?> 元 
</div></td> 

<td height="20"><div align="center" style="color: #000000"> 会 员 价 : </div></td> 

<td height="20"><div align="left"><?php echo S$info[ ‘huiyuanjia’];?> 元 
</div></td> 

<td height="20"><div align="center" style="color: #000000"> 折 扣 : </div></td> 

<td height="20"><div align="left"><?php echo (@ceil(($info[ ‘huiyuanjia’]/ 
$info[ ‘shichangjia’])*100))."%";?></div></td> 

</tr> 

se 

<td height="20" colspan="6" width="461"><div align="center">gnbsp’; gnbsp; gnbsp; 
&nbsp;<a href="addgouwuche.php?id=<?php echo $info[‘\id’];?>"><img src="images/ 
bl.gif" width="50" height="15" border="0" style=" cursor:hand"></a></div></td> 

</tr> 

EE 

<td height="10" colspan="7" background="images/linel.gif"></td> 

x/ 

<?php 

}while ($info=mysqli fetch array($sql)); 

} 
?> 
</table> 


9.6.3 ”推荐 产品 频道 


该 页 面 为 单 击 导航 条 中 的 “推荐 产品 ”链接 后 转 到 的 页 面 showtuijian.php， 主 要 是 显示 数据 库 
中 推荐 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完成 的 效果 如 图 9-44 所 示 。 


价 bvampp\tcocsshopwshowuhanphp EE 
WD ore ernenuote boton she ~ 
& 。” 萝 翠 搞 衣 
J 


‘oe 


首 ”页 | 最 新 上 染 | 失 产品 















站 产品 产品 分 类 | 用 户 中 心 订单 相让 | 风物 车 





< 
body Tax365 vv 加 


图 9-44 ”推荐 产品 的 页 面 
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推荐 产品 的 功能 和 最 新 上 架 频道 功能 基本 上 相同 ， 不 同 之 处 就 是 在 于 推荐 时 从 数据 库 查 询 的 
代码 不 同 ， 主 要 代码 不 同 部 分 如 下 所 示 : 
<?php 
$sql=mysqli query($conn,"select count (*) as total from tb shangpin where 
tuijian=1 "); 
// 从 tb_shangpin 数 据 表 中 查询 出 tuijian=1 的 商品 
$info=mysqli fetch array($sql); 
$total=$info[ ‘total’]; 
if($total==0) 
echo "本 站 暂 无 推荐 产品 !"; 
} 
else 
{ 





ra 


9.6.4 热门 产品 频道 


该 页 面 为 单 击 导航 条 中 的 “热门 产品 ”链接 后 转 到 的 页 面 showhotphp， 主 要 是 显示 数据 库 中 
热门 的 商品 。 
首先 完成 静态 页 面 的 设计 ， 该 页 面 完成 的 效果 如 图 9-45 所 示 。 








价 bvamppwtcocashopwhowotphp -Ox 
pre en meruphp bettom.phe T 
入 翡 妇 听 表 
i JADE WEN 
首 。 商量 型 上当] 失 和 产品 | 热天 品 产品 分 芭 | 用 户 中 C 
EE 


用 户 系 绽 : 





body 7003558 ~ 加 


图 9-45 热门 产品 的 页 面 


热门 产品 页 面 的 功能 代码 如 下 所 示 : 
<?Pphp 
$sql=mysqli query($conn,"select * from tb_ shangpin order by cishu desc 
Limit OrLO")y 

// 从 tb_shangpin 数 据 表 中 查询 出 10 条 的 热门 品牌 

$info=mysqli fetch array($sql); 

if ($info==false) 

echo "本 站 暂 无 热门 产品 !"; 
和 
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else 


9.6.5 ”产品 分 类 频道 


该 页 面 为 单 击 导航 条 中 的 “产品 分 类 ”链接 后 转 到 的 页 面 showfenlei.php， 按 商品 的 分 类 显示 
不 同 的 商品 。 


首先 完成 静态 页 面 的 设计 ， 该 页 面 完 成 的 效果 如 图 9-46 所 示 。 

















下 [TX] 
CO 人 日 127.0.0.1 BF Y 
1 | ©O 0mm 电子 亲生 网 站 十 局 > 
和 提 。” 戎 惧 扩 太 
ABE NES Ox: [i 
首页 | 最 新 上 架 | 排 基 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 二 而 | 丙 物 车 月 户 jsie 败 好 起 注 消 要 开 
名 镜 风 棕 流行 风 榜 国 办 风格 网 
肌 户 系统 
si 本 夫 商 品 )> 传 统 只 信 J 
1704 
提交 注册 本 @ 取 召 
训 闻 公 赂 : 更 名 77 
2 J 
,过 暴发 瘦 项 隐 短 浊 
Fe 
» 2017 看 页 巴 本 守 拘 时 





图 9-46 产品 分 类 的 页 面 
分 类 功能 的 代码 如 下 所 示 : 


<?php 
if($_GET[\id’]=="") 
$sql=mysqli_query($conn,"select * from tb type order by id desc limit 
0,1"); 
// 从 tb_type 数 据 表 中 查询 出 所 有 的 商品 分 类 
$info=mysqli fetch array($sql); 
$id=$info[‘id’]; 
} 
else 
{ 
$id=$_GET[‘id’]; 
} 
$sqll=mysqli query ($conn,"select * from tb type where id=".$id.""); 
$infol=mysqli fetch array($sql1); 


$sql=mysqli query($conn,"select count(*) as total from tb shangpin where 
typeid='".$id."' order by addtime desc "); 
$info=mysqli fetch array($sql); 
$total=$info[ ‘total’]; 
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9.6.6 ”产品 搜索 结果 


一 般 的 大 型 网 站 都 存在 搜索 功能 ， 在 首页 中 要 设置 商品 的 搜索 功能 。 输 入 搜索 的 商品 后 ， 单 
击 搜索 按钮 ， 要 打开 的 页 面 就 是 这 个 商品 搜索 结果 页 面 serchorder.php。 
由 上 面 的 功能 分 析出 发 ， 设 计 好 的 商品 搜索 结果 页 面 如 图 9-47 所 示 。 

















> 
a 





图 9-47 ”产品 搜索 结果 页 面 
相关 的 程序 代码 分 析 如 下 : 





PHP 7.0 + MySQL 网 站 开发 全 程 实 例 





// 按 分 类 名 称 查 询 tb_shangpin 数 据 表 
} 
else 
{ 
if ($mh=="1"){ 
$sql=mysqli query($conn,"select * from tb shangpin where huiyuanjia $dx".$jg." 
and typeid='".$1b."' and mingcheng like '%".$name."%®'"); 
0 
// 按 会 员 价 查询 tb_shangpin 数 据 表 
elsef{ 
$sql=mysqli query($conn,"select * from tb _ shangpin where huiyuanjia $dx".$jg." 
and typeid='".$1b."' and mingcheng = '".$name."™'"); 
} 
} 
$info=mysqli fetch array($sql); 
if ($info==false){ 
echo "<script language='javascript'>alert(' 本 站 暂 无 类 似 产 品 !');history. 
go(-1) ;</script>"} 
} 
else{ 
?> 
<table width="530" border="0" align="center" cellpadding="0" cellspacing="1" 
bgcolor="#CCCCCC"> 
<tr bgcolor="#FOFOFO"> 
<td width="92" height="25"><div align="center" style="color: #990000"> 名 称 
</div></td> 
<td width="83"><div align="center" style="color: #990000"> 品 牌 </div></td> 
<td width="62"><div align="center" style="color: #990000"> 市 场 价 </div></td> 
<td width="62"><div align="center" style="color: #990000"> 会 员 价 </div></td> 
<td width="161"><div align="center" style="color: #990000"> 上 市 时 间 </div></td> 
<td width="48"><div align="center" style="color: #FFFFFF"><span 
class="stylel"></span></div></td> 
<td width="42"><div align="center" style="color: #990000"> 操 作 </div></td> 
</tr> 
<?php 
do{ 
2> 
<tr bgcolor="#FFFFFF"> 
<td height="25"><div align="center"><?php echo $info[‘mingcheng’];?> 
</div></td> 
<td height="25"><div align="center"><?php echo $info[ ‘pinpai’];?></div></td> 
<td height="25"><div align="center"><?php echo $info[‘shichangjia’];?> 
</div></td> 
<td height="25"><div align="center"><?php echo $info[‘huiyuanjia’];?> 
</div></td> 
<td height="25"><div align="center"><?php echo $info[ ‘addtime’];?></div></td> 
<td height="25"><div align="center"><a href="lookinfo.php?id=<?php echo 
$info[ ‘id’];?>"> 查 看 </a></div></td> 
<td height="25"><div align="center"><a href="addgouwuche.php?id=<?php echo 
$info[ ‘id’];?>"> 购 物 </a></div></td> 
</tr> 
<?php 
}while ($info=mysqli fetch array($sql)); 
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1 
和 > 
</table></td> 
</tr> 
</table> 


到 这 里 ， 就 完成 了 商品 相关 动态 页 面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 定购 的 功能 。 


网 站 的 购物 车 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 、 网 上 定购 与 产品 结算 功能 ， 在 网 站 建设 中 这 块 知识 统 
称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 进行 产品 结算 ， 通 过 这 个 功能 ,用 户 在 选择 自己 喜 
欢 的 产品 后 可 以 通过 网 站 确认 所 需要 购买 的 产品 , 输入 联系 方式 , 提交 后 写 入 数据 库 , 方便 网 站 管 
理 者 进行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 


9.7.1 ” 放 入 购物 车 


addgouwuche.php 页 面 在 前 面 的 代码 中 经 常 应 用 到 ， 就 是 单 击 “ 购 买 ” 按 钮 后 ， 需 要 调用 的 页 
面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完全 是 PHP 代 码 ， 如 图 9-48 所 示 。 


面 ER -Ox 





amn php 





eta http-equiv="Content-Type" content="text/htnl; charset=utf-8" 





"select * 
($sql); 


from tb_shangpin where id="",$id.""); 


{ 
该 商品 已 经 雪 元 !' ) ;history,back();</script>"; 





S_S5ESSION['producetist SSION[ 'producelist'].$ 
$_SESSION[ 'quatity']-$. IN['quatity'] ."1@" 
header ("location:gouwuche.pho"): 





图 9-48 addgouwuche.php 页 面 的 设计 


代码 分 析 如 下 : 


<?php 

session start(); 

include ("conn.php"); 

if($_SESSION[ ‘username’ ]==""){ 
echo "<script>alert (' 请 先 登 录 后 购物 !') ;history.back();</script>"; 
exit; 


} 
// 判 断 是 否 已 经 登录 
$id=strval($_GET[\id’]); 
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$sql=mysqli query($conn,"select * from tb shangpin where id="'".$id."'"); 
$info=mysqli fetch array($sql); 
if($info[ ‘shuliang’ ]<=0){ 
echo "<script>alert (' 该 商品 已 经 售 完 !') ;history.back();</script>"; 
exit; 
} 
// 判 断 是 否 还 有 产品 
Sarray=explode ("@",$_SESSION[ ‘producelist’]); 
for ($i=0;$i<count ($array) -1;$i++) { 
if($array[$i]==$id){ 


echo "<script>alert (' 该 商品 已 经 在 您 的 购物 车 中 !') ;history.back(); 
</script>"; 


// 判 断 是 否 重 复 购买 
exit; 
. 
T 
$_SESSION[ ‘producelist’]=$_ SESSION[ ‘producelist’].$id."@"; 
$_SESSION[ ‘quatity’]=$_ SESSION[ ‘quatity’]."1@"; 
header ("location:gouwuche.php"); 


// 实 现 统计 累加 的 功能 并 进行 转向 


?> 
ys 有 

session 在 PHP 编 程 技术 中 ， 是 占有 非常 重要 份量 的 函数 。 由 于 网 页 是 一 种 无 状态 的 连接 程 
序 ， 因 此 无 法 得 知 用 户 的 浏览 状态 。 必 须 通 过 session 变 量 记录 用 户 的 有 关 人 信息， 以 供用 户 再 次 
以 此 身份 ， 对 服务 器 提供 要 求 时 进行 确认 。 


9.7.2 ”清空 购物 车 


在 使 用 购物 车 定购 产品 过 程 中 通过 单 击 “ 删 除 ” 和 “清空 购物 车 ”文字 链接 , 能 够 调用 removegwc.php 
页 面 ， 通 过 里 面 的 命令 可 以 清空 购物 车 中 的 数据 统计 ， 设 计 的 PHP 命 令 如 图 9-49 所 示 。 


付 ovamppwedocsshopvemovegwcphp = OX 





$id=$_ 
$arraysp=explode 
Sarraysl=explode 
v for($i=0;$iccount( 
if($arraysp[$ 
$arraysp[$ 
$arraysl[$i]= 
了 
3 
$_SESSION[producelist]=implode("@", $arraysp); 
$_SESSION[quatity] =implode("@", $arraysl); 
header ("location:gouwuche.php"); 








$_SESSION[producelist]); 
$_SESSION[quatity]); 
raysp) ;$i++){ 

id) 半 





mv ms 7265 图 


图 9-49 removegwc.php 页 面 
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清除 订单 的 代码 如 下 : 


<?php 
session start(); 
$id=$_GET[‘id’]; 
$arraysp=explode ("@",$_SESSION[ ‘producelist’]); 
$arraysl=explode ("@",$_SESSION[ ‘quatity’]); 
for ($i=0;$i<count ($arraysp) ;$i++) { 
if($arraysp[$i]==$id){ 
$arraysp[$i]=""; 
$arraysl[$i]=""; 
3 
} 
$_SESSIONT[ ‘producelist’]=implode ("@", $arraysp); 
$_SESSION[ ‘quatity’]=implode("@", $arrays1); 
header ("location:gouwuche.php"); 
?> 


通过 上 面 的 命令 可 以 清空 购物 车 里 的 订单 ， 并 返回 gouwuche.php 页 面 重 新 进行 产品 定购 。 


9.7.3” 收 款 人 信息 


用 户 登录 后 选择 将 商品 放 入 购物 车 ， 单 击 结算 中 心 页 面 上 的 “去 收银 台 ” 文 字 链 接 ， 则 打开 
订单 用 户 信息 确认 页 面 gouwusuan.php， 在 该 页 面 中 设置 收 货 人 的 详细 信息 ， 设 置 的 结果 如 图 9-50 
所 示 。 
tt 


pote Cleft nenuphe 。 hoton.php 
mm aa | 


首 。 页 | 最 新 上 加 1 推 逢 产品 1 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查 亲 风物 车 





body 75x44 ~ 区 


图 9-50 收 款 人 信息 页 面 
9.7.4 生成 订单 功能 
单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd.php 页 面 ， 该 页 面 的 功能 是 把 订单 写 入 数据 库 后 返 
回 gouwusuan.php 页 面 ， 有 具体 代码 如 下 : 
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<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
session start(); 
include ("conn.php"); 
$sql=mysqli query($conn,"select * from tb user where name='".$ SESSION 
['username']."'")7 
$info=mysqli fetch array($sql); 
$dingdanhao=date ("YmjHis") .$info['id']; 
$spc=$_SESSION['producelist']; 
$slc= $_SESSION['quatity']; 
$shouhuoren=$_POST['name2']; 
$sex=$_POST['sex']; 
$dizhi=$_ POST['dz']; 
$youbian=$_POST['yb']; 
$tel=$_POST['tel']; 
$email=$ POST['email']; 
$shff=$_POST['shff"']; 
$zZfff=$ POST['zfff"]; 
if(trim($_ POST['ly'])==""){ 
$leaveword=""; 
} 
else{ 
$leaveword=$_POST['ly']; 
} 
$xiadanren=$_SESSION['username']; 
$time=date ("Y-m-j H:i:s"); 
$zt=" 未 作 任 何 处 理 "; 
$total=$_SESSION['total']; 
mysqli query($conn,"insert into tb dingdan(dingdanhao, spc,slc,shouhuoren, 
sex,dizhi,youbian,tel,email, shff,zfff,leaveword,time,xiadanren,zt,total) values 
('$dingdanhao', '$spc','$slc','$shouhuoren', '$sex','$dizhi','$youbian','$tel',’' 
$email','$shff','S$zfff','$leaveword', '$time','$xiadanren', '$zt','$total')"); 
header ("location:gouwusuan.php?dingdanhao=$dingdanhao"); 
?> 


9.7.5 “订单 查询 功能 


用 户 在 购物 时 ， 还 需要 知道 自己 在 近 段 时 间 内 一 共 购 买 了 多 少 件 商品 ， 可 以 单 击 导航 条 上 的 
“订单 查询 ”按钮 ， 打 开 查 询 输 入 的 页 面 finddd.php。 在 查询 文本 域 中 输入 客户 的 订单 编号 或 者 是 
下 订单 人 的 姓名 , 都 可 以 查 到 订单 的 处 理 情况 页 面 , 方便 与 网 站 管理 者 沟通 。 订单 查询 功能 和 首页 
上 的 商品 搜索 功能 设计 方法 是 一 样 的 , 需要 在 输入 的 查询 页 面 设置 好 数据 库 的 连接 , 设置 查询 输入 
文本 域 ， 建 立 查询 命令 ,具体 的 设计 分 析 与 前 面 的 搜索 功能 模块 设计 类 似 ， 完 成 的 效果 如 图 9-51 
所 示 。 
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独 pwampp\ntdocsshop\inddd php SR 
CE) pop et persphe botonpip 一 


























< 
body 75x44 ~ 区 


图 9-51 订单 查询 页 面 
整个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 都 已 经 完成 ， 还 有 其 他 一 些小 功能 页 面 这 里 就 
不 进行 介绍 了 , 用 户 在 使 用 时 可 以 根据 自己 的 需求 对 网 站 进行 一 定 的 完善 和 改进 , 达到 自己 的 使 用 
要 求 。 
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全 程 实例 八 : 莫 怒 电子 商城 后 全 


翡翠 电子 商城 前 台 主 要 实现 了 网 站 针对 会 员 的 所 有 功能 ， 包 括 了 会 员 注册 ， 购 物 车 以 及 留言 
的 功能 开发 。 但 一 个 完善 的 网 上 购物 系统 并 不 只 提供 给 用 户 注 册 , 还 要 给 网 站 所 有 者 一 个 功能 齐全 
的 后 台 管 理 功能 。 网 站 所 有 者 登录 后 台 可 以 进行 管理 ， 包 括 发 布 新 闻 公 告 、 会 员 注册 信息 的 管理 、 
回复 留言 、 商 品 维护 以 及 处 理 订单 等 。 本 章 主 要 介绍 翡翠 电子 商城 后 台 的 一 些 功能 的 开发 。 


电子 商城 系统 后 台 的 规划 
商品 管理 功能 的 开发 
用 户 管理 功能 的 开发 
订单 管理 功能 的 开发 
信息 管理 功能 的 开发 


医 C 细 电子 商城 系统 后 台 规 划 


第 10 章 全程 实 例 八 ;翡翠 电子 商城 后 台 


电子 商城 的 后 台 管理 系统 是 整个 网 站 建设 的 难点 , 它 包 括 了 几乎 所 有 的 常用 PHP 处 理 技术 ,也 
相当 于 一 个 独立 运行 的 系统 程序 。 实 例 的 后 台 主 要 实现 “商品 管理 ”“ 用 户 管理 ”“ 订 单 管理 ”以 
及 “信息 管理 ”4 大 功能 模块 ， 在 进行 具体 的 功能 开发 之 前 ， 和 网 站 前 台 的 制作 方法 一 样 ， 首 先 要 





进行 一 个 后 台 的 需求 整体 规划 。 


10.1.1 后 台 页 面 的 设计 


本 实例 将 所 有 制作 的 后 台 管理 的 页 面 放置 在 admin 文 件 夹 下 面 ， 和 单独 设计 一 个 网 站 一 样 需要 


建立 一 些 常用 的 文件 来， 如 用 于 连接 数据 库 的 文件 夹 conn、 


用 于 放置 网 页 样式 表 的 文件 夹 css、 放 


置 图 片 的 文件 夹 images， 以 及 用 于 放置 上 传 的 产品 图 片 文件 夹 upimages， 设 计 完 成 的 整体 文件 夹 及 


文件 结构 如 图 10-1 所 示 。 


X 或 
到 三。 光志 
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ee- 


co-" CR， 二 DY » ampp » hdoce » chop ，admin 
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下 dhargeadminphp 
dhangegoode php 





图 10-1 网 站 后 台 文 件 结构 
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该 网 站 后 台 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 上 来 说 并 不 比 开始 前 台 的 简单 。 对 需要 设计 的 


页 面 功能 分 析 如 下 : 


addgonggao.php: 增加 新 闻 公 告 的 页 面 
addgoods.php: 增加 商品 信息 的 页 面 
addleibie.php: 增加 商品 类 别 的 页 面 
admingonggao.php: 增加 商品 公告 的 页 面 
changeadmin.php: 管理 员 信息 变更 页 面 
changegoods.php: 商品 信息 变更 页 面 
changeleaveword.php: 会 员 留 言 变更 页 面 
chkadmin.php: 管理 员 登 录 验 证 页 面 
conn.php: 数据 库 连 接 文件 页 面 
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default.php: 后 台 登 录 后 的 首页 
deleted.php: 删除 订单 的 页 面 
deletefxhw.php: 删除 商品 信息 页 面 
deletegonggao.php: 删除 公告 信 ， 
deletelb.php: 删除 商品 大 类 页 面 
deleteleaveword.php: 删除 用 户 留言 页 面 
deletepingjia.php: 删除 商品 评论 页 面 
deleteuser.php: 删除 用 户 信 息 页 面 
dongjieuser.php: 冻结 用 户 处 理 页 面 
editgonggao.php: 编辑 公告 内 容 页 面 
editgoods.php: 编辑 商品 信息 页 面 
editleaveword.php: 编辑 用 户 留言 页 面 
editpinglun.php: 编辑 用 户 评论 页 面 

edituser.php: 编辑 用 户 信 息 页 面 

finddd.php: 订单 查询 页 面 

function.php: 调用 的 常用 函数 页 面 

index.php: 后 台 用 户 登 录 页 面 

left.php: 展开 式 树 状 导航 条 

lookdd.php: 查看 订单 页 面 

lookleaveword.php: 查看 用 户 留言 页 面 
lookpinglun.php: 查看 用 户 评论 页 面 
lookuserinfo.php: 查看 用 户 信息 页 面 

orddd.php: 执行 订单 页 面 

saveaddleibie.php: 保存 新 增 商 品 大 类 页 面 
savechangeadmin.php: 保存 用 户 信息 变更 页 面 
savechangegoods.php: 保存 经 修改 商品 信息 页 面 
saveeditgonggao.php: 保存 经 修改 公告 内 容 页 面 
savenewgonggao.php: 保存 新 增 公告 信息 页 面 
savenewgoods.php: 保存 新 增 商 品 信息 页 面 
saveorder.php: 保存 执行 订单 页 面 

showdd.php: 打印 订单 的 功能 页 面 
showleibie.php: 商品 大 类 显示 页 面 

top.php: 后 台 管 理 的 顶部 文件 





1.2 后台 管理 登录 页 面 


后 台 功 能 的 开发 和 网 站 前 台 的 功能 展示 开发 并 不 大 一 样 ， 前 台 除 了 功能 的 需求 之 外 ， 还 需要 


讲究 更 多 的 网 页 布局 ， 即 网 站 的 美工 设计 ， 后 台 的 开发 主要 重视 功能 的 需求 开发 ， 而 网 页 美工 可 以 


放 到 
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次 。 本 小 节 介绍 一 下 管理 员 从 网 站 后 台 登 录 到 进行 管理 具体 经 过 哪些 流程 ， 以 方便 读者 更 容 





第 10 章 全 程 实例 八 ， 翡翠 电子 商城 后 台 


易 了 解 后 面 小 节 的 内 容 。 

对 于 网 站 拥有 者 需要 登录 后 台 进 行 管理 网 上 购物 系统 ， 由 于 涉及 很 多 商业 机 密 ， 所 以 需要 设 
计 登 录用 户 确认 页 面 , 通过 输入 唯一 的 用 户 名 和 密码 来 登录 后 台 进 行 管理 。 本 网 上 购物 系统 为 了 方 
便 使 用 ， 只 需要 在 首页 用 户 系统 中 直接 输入 “用 户 名 ”为 admin，“ 和 密码 ”为 123456， 登 录 的 地 址 
为 : http://127.0.0.1/shop/admin/login.php， 如 图 10-2 所 示 。 


EE [I DO x 
所 CE 全 会 日 htipW127001 gy EE 
b | © | DR | 127901/shop/adminNognphp > |+ Go 











图 10-2 后 台 管理 登录 页 面 
单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 图 10-3 所 示 。 
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图 10-3 后台 管理 主 界面 
单 击 左边 树 状 的 管理 菜单 中 的 “商品 管理 ”菜单 项 ， 可 以 看 到 它 包含 了 “增加 商品 ”“ 修 改 
商品 ”“ 类 别管 理 ” 和 “添加 类 别 ”4 个 功能 选项 ， 通 过 这 4 个 功能 可 以 实现 商品 的 添加 、 修 改 管理 。 
如 图 10-4 所 示 为 增加 商品 页 面 。 
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图 104 “增加 商品 ”页 面 


如 果 想 实现 对 用 户 的 管理 ， 可 以 单 击 “ 用 户 管理 ”菜单 项 ， 里 面包 括 了 “会 员 管 理 ”“ 留 言 
管理 ”以 及 “更 改 管理 员 ”3 个 功能 选项 。 通 过 这 3 个 功能 选项 ， 后 台 管理 者 不 但 可 以 实现 对 注册 会 
员 的 删除 , 还 可 以 实现 相应 留言 的 删除 管理 , 对 于 后 台 登 录 的 admin 身 份 也 可 以 进行 变更 。 如 图 10-5 
所 示 为 对 后 台 管 理 者 进行 变更 。 
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图 10-5 后 台 管理 者 变更 页 面 
“订单 管理 ”是 购物 系统 后 台 管 理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”菜单 项 ， 可 以 看 到 其 包括 
“编辑 订单 ”和 “查询 订单 ”两 个 功能 选项 。 其 中 “编辑 订单 ”就 是 实现 前 台 会 员 下 订单 后 与 管理 
者 的 一 个 交互 ,管理 者 需要 及 时 处 理 订单 ， 并 进行 发 货 才 可 以 实现 购物 交易 ， “编辑 订单 ”的 页 面 
如 图 10-6 所 示 。 
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图 10-6 “编辑 订单 ”页 面 


单 击 “ 信 息 管理 ”菜单 项 可 以 看 到 其 包括 了 “管理 公告 ”“ 发 布 公告 ”和 “管理 评价 ”3 个 功 
能 ， 通 过 这 3 个 功能 能 够 实现 整个 网 站 的 即时 新 闻 发 布 ， 公 告 修 改 以 及 商品 评论 的 编辑 修改 功能 ， 


如 图 10-7 所 示 。 
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10.1.3 


图 10-7 “管理 公告 ”页 面 


通过 以 上 分 析 ， 管 理 者 登录 后 台 管 理 页 面 的 后 台 管 理 功能 非常 流畅 ， 能 够 非常 方便 进行 后 台 
管理 ， 这 也 是 需要 网 站 设计 者 与 管理 者 沟通 到 位 ， 问 清 需 求 后 才 可 以 规划 出 实用 的 网 站 后 台 。 


设计 后 台 管 理 


一 般 后 台 管 理 者 在 进行 后 台 管理 时 都 是 需要 进行 身份 验证 的 ， 实 例 用 于 登录 的 页 面 如 图 10-8 
所 示 ， 在 单 击 “ 登 录 ” 按 钮 后 ， 判 断后 台 登 录 管 理 者 身份 的 确认 动态 文件 为 chkadmin.php。 
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图 10-8 后 台 管理 登录 静态 页 面 效果 


该 页 面 的 制作 比较 简单 ， 主 要 的 功能 代码 如 下 : 


<script language="javascript"> 

function chkinput (form){ 
if(form.name.value==""){ 

alert ("请 输入 用 户 名 !")， 
form.name.select (); 
return (false); 

} 

if (form.pwd.value==""){ 
alert ("请 输入 用 户 密码 !") ; 
form.pwd.select (); 
return (false); 

} 

return (true) 7 
}// 单 击 登录 按钮 进行 表单 的 验证 

</script> 

<form name="forml" method="post" action="chkadmin.php" onSubmit="return 

chkinput (this)"> 
// 通 过 验证 后 转 到 chkadmin .php 进 行 判 断 


chkadmin.php 页 面 是 判断 管理 者 身份 是 否 正确 的 页 面 ， 使 用 PHP 编 写 的 代码 如 下 : 


<?php 
class chkinput{ 
Var $name; 
Var S$pwd; 
function chkinput ($x, $y) 
{ 
$this->name=$x; 
Sthis->pwd=SyY7 
} 
function checkinput () 
include (“conn.php’”); 
$sql=mysqli query ("select * from tb admin where name='".$this->name."'",$conn); 
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10.1.4 ”设计 树 状 菜 单 


后 台 管 理 的 导航 菜单 是 一 个 树 状 的 展开 式 菜单 ， 分 为 二 级 菜单 ， 在 单 击 一 级 菜单 时 可 以 实现 
二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver CC 2017 中 设计 的 样式 如 图 10-9 所 示 。 


SI 
三 党 


及 











Us | 加 





图 10-9 树 状 导航 菜单 
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而 实现 菜单 的 展开 和 合并 动态 功能 是 使 用 JavaScript 实 现 的 ， 核 心 的 代码 如 下 : 


<script language="javascript"> 
function openspgl(){ 
if(document.all.spgl.style.display=="none"){ 
document .all.spgl.style.display=""; 
document .all.dl.src="images/point3.gif"; 
1 
elsef 
document .all.spgl.style.display="none"; 
document .all.dl.src="images/point]l.gif"; 
} 
} 
function openyhgl (){ 
if(document .all.yhgl.style.display: 
document .all.yhgl.style.display=""; 
document .all.d2.src="images/point3.gif"; 
} 
elsef{ 
document .all.yhgl.style.display="none"; 
document .all.d2.src="images/pointl .gif"; 
小 
function openddgl (){ 
if(document .all.ddgl.style.displa 
document .all.ddgl.style.display=""; 
document .all.d3.src="images/point3.gif"; 
} 
else{ 
document .all.ddgl.style.display="none"; 
document .all.d3.src="images/pointl1.gif"; 
} 
3 
function opengggl(){ 
if(document .all.gggl.style.displa 
document .all .gggl.style.display="" 
document .all.d4.src="images/point3.gif"; 
elsef{ 
document .all.gggl.style.display="none"; 
document .all.d4.src="images/pointl1 .gif"; 
上 
</script> 


上 述 的 代码 经 常 应 用 于 网 站 的 动态 菜单 设计 ， 读 者 可 以 将 其 应 用 于 其 他 的 网 站 ， 甚 至 是 网 站 
的 前 台 菜 单 。 


贺 网 商品 管理 功能 


由 需求 出 发 ， 商 品 管理 包括 了 “增加 商品 ”“ 修 改 商 品 ”“ 类 别管 理 ” 和 “添加 类 别 ”4 个 功 
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能 主页 面 ， 本 节 介 绍 这 几 个 商品 管理 功能 页 面 的 实现 方法 。 


10.2.1 新 增 商品 


在 前 台所 有 展示 的 产品 都 是 要 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 字段 要 与 数据 库 中 保存 
商品 的 设计 字段 一 一 对 应 ， 实 例 设计 的 添加 商品 addgoods.php 静 态 页 面 效 果 如 图 10-10 所 示 。 


冯 Dapp hdceshop dinaddgood php -6x 
tc cmap T 





i | 重 三 ey 
bocy Px45 ~ 区 


图 10-10 添加 商品 的 页 面 效 果 


动态 的 程序 核心 代码 如 下 : 


<script language="javascript"> 
function chkinput (form) 
1 
if(form.mingcheng.value=="") 
. 
alert ("请 输入 商品 名 称 !"); 
form.mingcheng.select (); 
return (false); 
} 
if(form.huiyuanjia.value=="") 
下 
alert ("请 输入 商品 会 员 价 !"); 
form.huiyuanjia.select (); 
return (false); 
1 
if(form.shichangjia.value=="") 
{ 
alert ("请 输入 商品 市 场 价 !"); 
form.shichangjia.select (); 
return (false); 
} 
if(form.dengji.value=="" 
alert ("请 输入 商品 等 级 !") ; 
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form.dengji.select (); 
return (false) 7 
} 
if(form.pinpai .value=="") 
i 
alert ("请 输入 商品 品牌 !"); 
form.pinpai.select (); 
return (false); 
} 
if(form.xinghao.value=="") 
alert (" 请 输入 商品 型 号 !") 
form.xinghao.select() 7 
return (false) 7 
if (form.shuliang.value=: 
{ 
alert ("请 输入 商品 数量 !") ; 
form.shuliang.select (); 
return (false); 
下 
if(form.jianjie.value=="") 
下 
alert (" 请 输入 商品 简介 ! ") 
form.jianjie.select (); 
return (false); 
} 
return (true); 





} 
</script> 
// 进 行 表单 验证 
<form name="forml" enctype="multipart/form-data" method="post" action= 
"savenewgoods .php" onSubmit="return chkinput (this)"> 


// 验 证 后 提交 到 savenewgoods .php 页 面 进行 处 理 


savenewgoods.php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 码 如 下 : 


<?php 
include (“conn.php”); 
if(is numeric($_ POST[‘shichangjia’ ])==false 11 
is_numeric($_ POST[ ‘huiyuanjia’])==false) 
{ 
echo "<script>alert (' 价 格 只 能 为 数字 ! ') ;history.back();</script>"; 
exit; 
} 
if(is numeric($ POST[‘shuliang’])==false) 
{ 
echo "<script>alert (' 数 量 只 能 为 数字 ! ') ;history.back();</script>"; 
exit; 
} 
$mingcheng=$_POST[ ‘mingcheng’ ]; 
$nian=$_POST[ ‘nian’]; 
$yue=$_POST[ ‘yue’]; 


316 


第 10 章 全程 实 例 八 ;翡翠 电子 商城 后 台 





$ri=$_POST[‘ri’]; 
$shichangjia=$ POST[ ‘shichangjia’]; 
$huiyuanjia=$_ POST[ ‘huiyuanjia’]; 
$typeid=$_ POST[ ‘typeid’]; 

$dengji=$ POST[ ‘dengji’]; 
$xinghao=$_POST[ ‘xinghao’]; 
$pinpai=$_ POST[ ‘pinpai’]; 
$tuijian=$_ POST[ ‘tuijian’]; 
$shuliang=$_POST[ ‘shuliang’]; 
S$upfile=$ POST[ ‘upfile’]; 

if (ceil(($huiyuanjia/$shichangjia)*100)<=80) 
{ 








S$tejia=1; 
} 
else 
{ 
$tejia=0; 
} 
function getname ($exname){ 
$dir = "upimages/"; 
// 列 出 产品 图 片 的 上 传 目录 
Si=17 
if(!is_dir(S$Sdir))1{ 
mkdir($dir,0777); 
. 
while(true){ 
if(!is file($dir.$i.".".S$exname)){ 
$name=$i.".".$exname; 
break; 
} 
$i++; 
} 
return $dir.$name; 
} 
$exname=strtolower (substr($_ FILES['upfile']['name'], (strrpos($_FILES['upfil 
e']['name'],'.')+1))); 
Suploadfile = getname ($exname); 
move_uploaded file($ FILES['upfile']['tmp name'], $uploadfile); 
if (trim($_FILES['upfile']['name'] !="")) 
{ 
$uploadfile="admin/".$uploadfile; 
中 
else 
{ 
Suploadfile=""7 
} 
$jianjie=$_POST[ “jianjie’]; 
$addtime=$nian."-".$yue."-".$ri; 
mysqli query("insert into tb shangpin (mingcheng,jianjie,addtime,dengji, 
xinghao, tupian,typeid, shichangjia,huiyuanjia,pinpai,tuijian,shuliang,cishu)val 
ues('$mingcheng','$jianjie','$addtime','$dengji','$xinghao','$uploadfile','$ty 
peid','$shichangjia','$huiyuanjia','$pinpai','$tuijian','$shuliang','0')",$con 
n); 
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echo "<script>alert (' 商 品 " .$mingcheng." 添 加 成 功 !'); 
window.location.href='addgoods .php';</script>"; 
es 


// 上 传 成 功 转向 addgoods .php 页 面 
上 述 PHP 的 代码 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 


10.2.2 ”修改 商品 

在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “修改 商品 ”功能 选项 来 进 
行商 品 信息 的 调整 ， 在 后 台中 单 击 “ 修 改 商 品 ” 打 开 的 是 editgoods.php 页 面 。 

步 又 014 使 用 Dreamweaver CC 2017 制 作 的 静态 页 面 效果 如 图 10-11 所 示 。 


雷 bwvemppWedocsshopedminvediooodsphp 2 


fontcss mp T 


商品 信息 编辑 
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图 10-11 修改 商品 信息 静态 页 面 效果 


步骤 024 在 该 页 面 中 选中 “ 复 选 ” 复 选 框 ， 单 击 “ 删 除 选择 ”按钮 可 以 实现 链接 到 
deletefxhw.php 页 面 来 进行 删除 商品 信息 操作 。 从 数据 库 中 删除 商品 信息 ， 使 用 的 代码 如 下 : 


<?php 
include ("conn.php"); 
while(list ($name, $value)=each($_POST)) 
{ 
$sql=mysqli query ("select tupian from tb_shangpin where id='".$value."'", $conn); 
$info=mysqli _ fetch array($sql); 
if($info['tupian']!="") 
{ 
@unlink (substr ($info['tupian'],6, (strlen($info['tupian'])-6))); 


} 
$sqll=mysqli_ query($conn,"select * from tb dingdan "); 
while($infol=mysqli fetch array($sql1)) 
{ S$idl=$infol['id']; 
$array=explode ("@", $infol['spc']); 
for($i=0;$i<count ($array) ; $i++) { 
if($array[$i]==$value) 
{ 
mysqli query($conn,"delete from tb dingdan where id="'".$idl."'"); 
上 
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mysqli_ query ($conn,"delete from tb shangpin where id='".$value."'"); 
mysqli query($conn,"delete from tb pingjia where spid='".$value."'"); 
| 
header ("location:editgoods.php"); 
全 


步骤 034 通过 单 击 “ 更 改 ” 文 字 链 接 能 打开 changegoods.php 页 面 来 进行 商品 信息 的 变更 ， 
该 页 面 设计 的 样式 和 添加 商品 时 的 样式 是 相同 的 ， 如 图 10-12 所 示 。 


请 wamppwtdocsshopvadminwhangegoodsphp -Ox 
SRD fontss -mp T 





到 KR ] 卫衣 
th 落 zx ~ 图 
图 10-12 ”修改 商品 字段 采集 页 面 


步骤 044 在 编辑 商品 信息 之 后 ， 单 击 “ 更 改 ”按钮 提交 表单 到 savechangegoods.php 页 面 进行 
数据 库 的 更 新 操作 ， 核 心 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?PhP 

include ("conn.php"); 
$mingcheng=$_POST['mingcheng']; 
$nian=$_POST['nian']; 
$yue=$_POST['yue']; 
$ri=$_POST['ri']; 
$shichangjia=$_POST['shichangjia']; 
$huiyuanjia=$_POST['huiyuanjia']; 
$typeid=$_POST['typeid']; 

$dengj _POST['dengji']; 
$xinghao=$_POST['xinghao']; 
$pinpai=$_POST['pinpai']; 
$tuijian=$_POST['tuijian']; 
$shuliang=$_POST['shuliang']; 
//$upfile=$_ POST[upfile]; 





if(ceil(($huiyuanjia/$shichangjia)*100)<=80) 
{ 


$tejia=1; 
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} 
else 
{ 
$tejia=0; 
} 
if(@ $upfile!="") 


{ 
$sql=mysqli query($conn,"select * from tb shangpin where id=".$ GET[id].""); 


$info=mysqli fetch array($sql); 
@unlink (substr ($info['tupian'],6, (strlen($info['tupian'])-6))); 
i 


function getname ($exname){ 
$dir = "upimages/"; 
Si=17 
if(!is dir($dir))t{ 
mkdir($dir,0777); 
} 


while(true){ 
if(!is file($dir.$i.".".S$exname)){ 
$name=$i.".".S$exname; 
break; 
} 
$i++2 


} 


return S$dir.$name; 


} 

$exname=strtolower (substr($ FILES['upfile']['name'], (strrpos($_FILES['upfil 
['name'],'.')+1))); 

Suploadfile = getname ($exname); 
move_uploaded file($ FILES['upfile']['tmp name'], $uploadfile); 


$uploadfile="admin/".S$uploadfile; 


$jianjie=$_POST['jianjie']; 
$addtime=$nian."-".$yue."-".$ri; 


mysqli_query($conn,"update tb_ shangpin set mingcheng='$mingcheng',jianjie= 
ianjie',addtime='$addtime',dengji='$dengji',xinghao='$xinghao',tupian="'$upl 


oadfile',typeid='$typeid',shichangjia='$shichangjia',huiyuanjia='$huiyuanjia', 
Pinpai="'$pinpai',tuijian="'$tuijian',shuliang="'$shuliang' where id=".$ GET['id'].""); 


</s 
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echo "<script>alert(' 商品 ".$mingcheng." 修改 成 功 !');history.back();; 
CFRPE> 
2 


更 新 数据 库 主 要 应 用 到 了 update 这 个 数据 库 更 新 的 命令 。 


第 10 章 ”全程 实例 八 ， 翡翠 电子 商城 后 台 
10.2.3 ”类 别管 理 


单 击 商品 的 “类 别管 理 ” 功 能 选项 可 以 进行 商品 类 别 的 删除 操作 ， 选 中 “操作 ” 复 选 框 ， 再 
单 击 “ 删 除 选项 ”按钮 即 可 将 类 别 从 数据 库 中 删除 ， 该 功能 首页 为 showleibie.php。 
使 用 Dreamweaver CC 2017 设 计 的 页 面 静 态 效果 如 图 10-13 所 示 。 该 页 面 主要 实现 从 类 别 的 数据 
表 中 查询 出 相应 的 数据 绑 定 到 该 页 面 。 
者 ovampp\htdocsshopvadmin\showleibie php 六 
汰 RD font <s Ccom.php 学 
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图 10-13 ”类 别管 理 主页 面 


选中 相应 的 类 别 复 选 框 ， 单 击 “ 删 除 选 项 ”按钮 提交 表单 到 deletelb.php 动 态 页 面 进 行 删 除 类 
别 ， 在 删除 时 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 通 过 商品 的 id 同 时 删除 tb_type 和 tb_shangpin 即 可 
实现 ， 实 现 删 除 类 别 的 代码 如 下 : 
<?php 
include (“conn.php”); 
while(list ($name, $value)=each($_POST)){ 
mysqli_query($conn,"delete from tb type where id='".$value."'"); 
// 删 除 类 别 
mysqli_query(S$conn ,"delete from tb_shangpin where id='".$value."'"); 
// 删 除 类 别 下 的 商品 
} 
header ("location:showleibie.php"); 


// 删 除 成 功 转向 showleibie .php 页 面 


?> 


10.2.4 添加 类 别 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 台 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开发 中 经 
常 有 一 级 分 类 、 二 级 分 类 甚至 三 级 分 类 ， 其 中 还 涉及 菜单 的 二 级 联动 问题 。 本 实例 只 建立 了 一 级 分 
类 ， 管 理 者 可 以 在 后 台 直 接 添加 一 级 分 类 ， 添 加 类 别 功 能 的 主页 面 是 addleibie.php。 

使 用 Dreamweaver CC 2017 设 计 addleibie.php 页 面 的 静态 效果 如 图 10-14 所 示 。 
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国 Dp:wampp\htdocs\shop\admin\addleibie php Sox 
法 RD ant T 





body 460x136 ~ 图 


图 10-14 ”设计 的 增加 类 别 主页 效果 


在 单 击 “ 增 加 ”按钮 时 要 进行 表单 验证 ， 并 提交 到 saveaddleibie.php 页 面 进行 插入 数据 库 的 操 
作 ， 该 页 面 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 

<?php 

$leibie=$_POST['leibie']; 

include ("conn.php"); 

$sql=mysqli_query ($conn,"select * from tb type where typename='".$leibie.™"'"); 

$info=mysqli fetch array($sql); 

if ($info!=false){ 

echo"<script>alert (' 该 类 别 已 经 存在 !') ;window.location.href='addleibie. php'; 

</script>"; 

exit; 

} 

mysqli_query($conn,"insert into tb type (typename) values ('$leibie')"); 

echo"<script>alert(' 新 类 别 添加 成 功 !') ;window.location.href='addleibie. php'; 
</script>"; 

?> 

// 添 加 成 功 指向 addleibie.php 


在 代码 编写 时 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 要 加 入 一 个 判断 。 


区 网 用 户 管理 功能 


用 户 管理 功能 与 前 台 的 用 户 注册 功能 是 互相 对 应 的 ， 对 于 购物 网 站 来 说 ， 一 个 完整 的 用 户 管 
理 系 统一 定 要 有 一 个 功能 比较 强大 的 用 户 后 台 方 便 进行 管理 ， 实 例 中 制作 了 “会 员 管理 ” “留言 管 
理 ” 和 “更 改 管理 员 ”3 个 功能 选项 ， 本 节 介 绍 这 几 个 功能 的 实现 方法 。 





10.3.1 会 员 管 理 


会 员 的 管理 功能 主要 是 指 能 够 在 后 台 实 现 会 员 的 删除 操作 ， 对 一 些 会 员 还 能 够 实现 “冻结 ” 


的 操作 , 即 保留 会 员 的 信息 , 但 禁止 其 在 前 台 进 行 购物 及 发 言 。 会 员 管理 功能 的 首页 为 edituser.php， 
制作 的 详细 步骤 如 下 : 


步 又 014 使 用 Dreamweaver CC 2017 设 计 的 页 面 如 图 10-15 所 示 。 
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示 pvampp\ntdocs\shop\admin\edituser php Sn 
RD fontcss Ccom.php 





;本 站 共有 注册 用 户 胃 位 每 页 呈 示 图 位 第 图 页 共 田 页 盟 “ « 荔 嘱 田 咖 表 * 
测 国 
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10-15 会员 管 理 主页 edituser.php 


步 又 024 选中 “删除 ” 复 选 框 ， 单 击 “删除 选项 ”按钮 能 够 提交 表单 到 deleteuserphp 动 态 页 
面 ， 实 现 会 员 数 据 删 除 的 操作 ， 该 页 面 的 程序 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 

<?php 

include ("conn.php"); 

while(list ($name, $value)=each ($_POST)) 

mysqli_query($conn,"delete from tb user where id=".$value.""); 
mysqli_query($conn,"delete from tb pingjia where userid=".S$value.""); 
mysqli_query ($conn,"delete from tb _ leaveword where userid=".$value.""); 

header ("location:edituser.php"); 

?> 


在 删除 会 员 时 同样 要 注意 删除 数据 库 中 tb_user、tb_pingjia 和 tb_leaveword 这 3 个 数据 表 中 所 
有 关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管理 主页 面 。 





步骤 034 在 单 击 “ 查 看 详细 ”链接 后 ， 打 开 的 是 用 户 信 息 的 页 面 lookuserinfo.php， 设 计 的 页 
面 如 图 10-16 所 示 。 


休 pwampp\htdocsshopvsdminNookuserinfo php -Ox 
Rfontcss comphp 


654x276 ~ 


图 10-16 ”用户 信 息 页 面 lookuserinfo.php 





323 


PHP 7.0 + MySQL 网 站 开发 全 程 实 例 





在 程序 的 编写 时 实现 “冻结 ”和 “解冻 ”其 实 非常 简单 ， 只 需 用 赋值 为 0 或 者 1 来 区 分 是 否 冻 
结 ， 在 查询 会 员 信息 时 按 查 询 是 0 或 者 是 1 来 为 会 员 设置 权限 。 代 码 如 下 : 
<?php 
$sql=mysqli query($conn,"select * from tb user where id=".$id.""); 
$info=mysqli fetch array($sql); 
if ($info['dongjie']==0) 
|, 
echo "冻结 该 用 户 "; 
} 
else 
{ 
echo "解除 冻结 "7 


2> 


10.3.2 ”留言 管理 


当 会 员 在 购物 时 遇 到 问题 可 以 直接 通过 留言 功能 和 管理 者 进行 沟通 ， 后 台 管理 者 要 及 时 浏览 
会 员 的 留言 并 进行 相应 的 处 理 , 对 于 一 些 没 有 价值 的 留言 可 以 进行 直接 删除 的 操作 。 用 于 留言 管理 
的 主页 面 是 lookleaveword.php 页 面 。 
制作 lookleaveword.php 页 面 效 果 如 图 10-17 所 示 。 
函 DiwamppNhtdocs\shop\admin\ookjeaveword php* -Ox 


RD fontcss CC comphp functon.php T 
到 








图 10-17 留言 处 理 主页 面 lookleaveword.php 
该 页 面 也 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ,选中 “删除 ” 复 选 杠 ， 单 击 “ 删 
除 选项 按钮 提交 表单 信息 至 deleteleaveword.php 页 面 进行 删除 数据 的 操作 ， 实 现 删除 的 代码 如 下 : 


<?php 
include ("conn.php"); 
while(list ($name, $value)=each ($_POST)) 





mysqli_ query($conn,"delete from tb leaveword where id='".$value."'"); 


} 

header ("location:lookleaveword.php"); 
> 

// 删 除 成 功 返 回 lookleaveword.php 
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10.3.3 更改 管理 员 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 名 和 密码 都 是 admin， 在 提交 给 网 站 管理 者 时 ， 为 了 安全 
起 见 ， 管 理 者 要 能 够 实现 对 后 台 管 理 者 的 用 户 名 和 密码 进行 修改 ， 实 现 该 功能 的 主页 面 是 
changeadmin.php。 





制作 的 更 改 管理 员 主 页 changeadmin.php 的 效果 如 图 10-18 所 示 。 


者 pwamppuntdecs\shop\admin\changeadmin pnp SE 


源 民 本 nt T 
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10-18 ”网 站 管理 者 后 台 修改 主页 面 


在 输入 新 旧 管 理 员 的 用 户 名 和 密码 后 ， 再 单 击 “更 改 ” 按 钮 就 可 以 提交 表单 进行 验证 ， 并 提 
交 到 savechangeadmin.php 进 行 数据 更 新 的 操作 ， 实 现 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 

$n0=$_POST['n0']; 

$n1=$_POST['n1']; 

$p0=md5 ($_POST['p0']); 

$pl=trim($_POST['p1']); 

include ("conn.php"); 





$sql=mysqli query($conn,"select * from tb admin where name='".$n0."'"); 
$info=mysqli _ fetch array($sql); 
if ($info==false) 
| 
echo "<script>alert (' 不 存在 此 用 户 !') ;history.back();</script>"; 
exit; 
} 
else 
! 
if($info['pwd']==$p0) 
{ 
if($n1!="") 


mysqli query($conn,"update tb admin set name='".$nl."'where id=".$info 
ed 
es ); 
} 
if(Sp1!="") 
$pl=md5 ($p1); 
mysqli_ query($conn,"update tb admin set pwd='".$pl."' where id=".$info 
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} 
} 
else 
echo "<script>alert (' 原 密码 输入 错误 !') ;history.back();</script>"; 
exit; 
} 
} 
echo "<script>alert (' 更 改 成 功 !') ;history.back();</script>"; 
2> 


该 程序 首先 对 管理 员 的 用 户 名 进行 验证 ， 判 断 正 确 后 才 进行 更 新 数据 ， 并 显示 更 新 成 功 。 


苹 C 风 订单 管理 功能 


订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 者 而 言 一 定 要 及 时 登录 后 台 对 订单 进行 管理 
并 及 时 发 货 。 实 例 在 管理 员 登 录 后 台 时 把 订单 管理 功能 的 页 面 放 到 了 默认 打开 的 页 面 , 主要 包括 了 
“编辑 订单 ”和 “查询 订单 ”两 个 功能 ， 下 面 分 别 进行 介绍 。 


10.4.1 编辑 订单 


所 谓 的 “编辑 订单 ”是 指 管理 者 在 登录 后 台 后 ， 对 会 员 提交 的 订单 进行 “已 收 款 ”“ 已 发 货 ” 
和 “已 收 货 ” 验 证 ， 同 时 要 及 时 打印 出 网 上 订单 提交 给 公司 进行 发 货 处 理 。 编 辑 订单 的 主页 是 
lookdd.php。 

步骤 014 设计 的 lookdd.php 页 面 效果 如 图 10-19 所 示 。 该 页 面 也 只 是 显示 简单 的 订单 信息 功 
能 ， 只 要 从 数据 库 中 查询 订单 进行 显示 即 可 。 


二 ovamppwtdoceshopwdmnuookdd php eT 
Dfontcss comn.pho T 


旬 四 
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10-19 查看 订单 页 面 ookdd.php 
步骤 024 设计 的 第 二 步 就 是 实现 单 击 “ 查 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd.php 
页 面 并 能 进行 打印 ， 效 果 如 图 10-20 所 示 。 
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条 pwamppWhtdocsshopvadminshowdd php -Ox 
SR font.cs mphp 了 


Ep | 打印 | 











ney DD | 7%5x34 ~ 加 
图 10-20 订单 详细 内 容 
showdd.php 页 面 中 需要 调用 函数 实现 打印 的 功能 ， 具 体 的 代码 如 下 : 


<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 


<title> 商 品 订单 </title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
<style type="text/css"> 
de 
@media print{ 
div{display:none} 
} 
.Style3 {color: #990000} 
--> 
</style> 
</head> 
<?PhP 
include ("conn.php"); 
$id=$_GET['id']; 


$sql=mysqli_ query($conn,"select * from tb dingdan where id='".$id."'"); 


$info=mysqli_ fetch array ($sql); 
$spc=$info['spc']; 
$slc=$info['slc']; 
$arraysp=explode ("@", $spc); 
$arraysl=explode ("@", $slc); 
> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<p>gnbsp;</p> 


<table width="600" border="0"align="center" cellpadding="0" cellspacing="0"> 


<tr align="center" bgcolor="#FFCF60"> 

<td height="20" colspan="2" bgcolor="#0099FF"> 商 品 订单 </td> 
</tr> 
<tr> 


<td width="448"” height="20"> 订 单 号 : <?php echo $info['dingdanhao'];?></td> 


<td width="152"><div align="right"> 
<script> 
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function prn(){ 

document .all .WebBrowser] .ExecWB (7,1); 
} 

</script> 


<object ID='WebBrowserl1' WIDTH=0 HEIGHT=0 CLASSID="'CLSID:8856F961- 


340A-11D0-A96B-00C04FD705A2'></object> 


<input type="button" value=" 打印 预览 " class="buttoncss" onClick="prn()"> 


&nbsp; 


<input type="button" value=" 打 印 " class="buttoncss" onClick="window.print ()"> 


</div></td> 
</tr> 
E> 
<td height="20" colspan="2"> 商 品 列表 (如 下 ): </td> 
</tr> 
</table> 


<table width="500" height="60" border="0" align="center" cellpadding="0" 


cellspacing="0"> 
<tr> 
<td bgcolor="#666666"><table width="500" border="0" 
cellpadding="0" cellspacing="1"> 
<tr bgcolor="#0099FF"> 
<td width="153" height="20"> 商 品名 称 </td> 
<td 80"> 市 场 价 </td> 
<td width="80"> 会 员 价 </td> 
<td 80"> 数 量 </td> 
<td 101"> 小 计 </td> 
</tr> 
<?php 
Stotal=07 
for ($i=0;$i<count ($arraysp) -1;$i++){ 
if($arraysp[$i]!=""){ 






align="center" 


$sqll=mysqli_ query($conn,"select * from tb shangpin where id='".$arraysp 


| 
$infol=mysqli fetch array($sqll1); 
$total=$total+=$arraysl [$i]*$infol['huiyuanjia']; 
<tr bgcolor="#FFFFFF"> 
<td height="20"><?php echo $infol['mingcheng'];?></td> 





<td height="20"><?php echo S$arraysl[$i];?></td> 


20"><?php echo $infol['shichangjia'];?></td> 
20"><?php echo $infol['huiyuanjia'];?></td> 


<td height="20"><?php echo $arraysl[$i]*$infol['huiyuanjia'];?></td> 


</tr> 
<?php 
} 


2> 
<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="5"> 
总 计 费 用 :<?php echo S$total;?> 
</td> 
</tr> 
</table></td> 
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</table> 
<table width="460" border="0" align="center" cellpadding="0" cellspacing="0"> 


xtr> 
<td 
<td 
云 /起 工 > 
<tr> 
<td 
<td 
<JEr> 
EE> 
<td 
<td 
</tr> 
<tr> 
<td 
<td 
<td 
<td 
</tr> 
<tr> 
<td 
<td 
<td 
<td 
</tr> 
<tr> 
<td 
<td 
<td 
<td 
Er 
EE 
<td 


width="81"” height="20"> 下 单 人 : </td> 
colspan="3"><?php echo $info['xiadanren'];?></td> 


height="20"> 收 货 人 : </td> 
height="20" colspan="3"><?php echo $info['shouhuoren'];?></td> 


height="20"> 收 货 人 地 址 : </td> 
height="20" colspan="3"><?php echo $info['dizhi'];?></td> 


height="20"> 邮 &nbsp; gnbsp; 编 : </td> 

width="145" height="20"><?php echo $info['youbian'];?></td> 
width="66"> 电 &nbsp; &nbsp; 话 : </td> 

width="158"><?php echo $info['tel'];?></td> 





height="20">E-mail:</td> 
height="20"><?php echo $info['email'];?></td> 
height="20">&gnbsp;</td> 
height="20">&nbsp;</td> 


height="20"> 送 货 方式 : </td> 
height="20"><?php echo $info['shff'];?></td> 
height="20"> 支 付 方式 : </td> 
height="20"><?php echo $info['zfff'];?></td> 


height="20" colspan="4"><span class="inputcssnul1"> 汇 款 时 注 明 您 的 订单 号 ! 


汇款 后 请 及 时 联系 我 们 ! </span></td> 


</tr> 
<tr> 
<td 


height="20">gnbsp;</td> 


<td height="20"><div align="center"><input type="button" onClick="window. 
close () " value=" 关 闭 窗口 "class="buttoncss"></div></td> 


<td 
<td 
</tr> 


height="20"> 创 建 时 间 : </td> 
height="20"><?php echo $info['time'];?></td> 


</table> 


</body> 
</html> 


步骤 034 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd.php 页 面 ， 进 行 订 
单 的 处 理 ， 上 面包 括 了 “已 收 款 ”“ 已 发 货 ” “已 收 货 ” 3 个 复 选 框 ， 对 其 进行 相应 的 处 理 ,如 图 10-21 


所 示 。 
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雷 owamppwdocsshooedmmerdercdorp> 
RD fonts -mo T 
































body T734375 ~ [Er 
图 10-21 执行 订单 orderdd.php 
步骤 044 单 击 “ 修 改 ” 按钮 ， 即 提交 表单 到 saveorder.php 页 面 进行 数据 的 修改 并 保存 ， 具 体 
的 代码 如 下 : 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
$ysk=$_POST['ysk']."g&nbsp;"; 


$yfh=$_POST['yfh']."g&nbsp;"; 
$ysh=$_POST['ysh']."é&nbsp; 





$zt=""; 
if($ysk!="gnbsp;"){ 
$zt.=$ysk; 


下 
if($yfh!="gnbsp;"){ 
$zt .=$yfh; 
} 
if($ysh!="gnbsp;"){ 
$zt.=$ysh; 
} 
if(($ysk=="&nbsp;") && ($yfh=="&nbsp;") && ($ysh=="&nbsp;")){ 
echo "<script>alert (' 请 选择 处 理 状态 !') ;history.back();</script>"; 
exit; 
} 
include ("conn.php"); 
$sql3=mysqli query($conn,"select * from tb dingdan where id='".$ GET 
Uh tt 
$info3=mysqli fetch array($sql3); 
if (trim($info3['zt'])==" 未 作 任何 处 理 ") { 
$sql=mysqli query($conn,"select * from tb dingdan where id='".$ GET[id]."'"); 
$info=mysqli fetch array($sql); 
$array=explode ("@", $info['spc']); 
$arraysl=explode ("@", $info['slc']); 


for ($i=0;$i<count ($array) ; $i++){ 
$id=$array[$i]; 
Snum=Sarrays1[Si]7 
mysqli query($conn,"update tb shangpin set cishu=cishu+'".Snum."'v 
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shuliang=shuliang-'".$num."' where id="'".$id."'"); 
} 
} 
mysqli query($conn,"update tb dingdan set zt='".$zt."'where id='".$ GET 
上 
header ("location:1lookdd.php"); 
全 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开发 完成 。 


10.4.2 ”查询 订单 


在 网 站 运营 一 段 时 间 后 ， 网 上 的 订单 会 越 来 越 多 ， 会 经 常 遇 到 会 员 查 询 订单 的 情况 ， 网 站 管 
理 者 同样 也 需要 一 个 订单 的 后 台 查 询 功能 , 才能 方便 地 找到 相应 的 订单 。 实 例 查询 和 显示 的 结果 是 
在 同一 个 页 面 ， 即 finddd.php。 

制作 的 finddd.php 页 面 的 效果 如 图 10-22 所 示 。 

二 ovwampp\tdocsshopvadminwinddd php 5 
顺利 fontcss ”comphp 了 














boy 蕉 617x 244 区 
图 10-22 查询 订单 finddd.php 


核心 程序 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title> 订 单 查 询 </title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<?php 
include ("conn.php"); 
人 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<p>gnbsp;</p> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="20" bgcolor="#0099FF"><div align="center" style="color: 
#FFFFFF"> 订 单 查询 </div></td> 
</tr> 
<tr> 
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<td height="50" bgcolor="#555555"><table width="550" height="50" 
"align="center" cellpadding="0" cellspacing="1"> 
> 
<td bgcolor="#FFFFFF"> 
<table width="550" height="50" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<script language="javascript"> 
function chkinput3 (form) 
{ 
if( (form.username.value== 
{ 
alert ("请 输入 下 订单 人 或 订单 号 "); 
form.username.select (); 
return (false); 





border=" 





&& (form.ddh.value=="")) 


| 


return(true); 


} 
</script> 
<form name="form3" method="post" action="finddd.php" onSubmit= 
"return chkinput3( this)"> 
<tr> 
<td height="25"><div align="center"> 下 订单 人 姓名 :<input 
type="text" name="username" class="inputcss" size="25" > 
订单 号 :<input type="text" name="ddh" size="25" class= 
"inputcss" ></div></td> 
</tr> 
<tr> 
<td height="25"> 
<div align="center"> 
<input type="hidden" valu 
<input name="button" type: 
id="button" value=" 查 找 "> 
</div></td> 
</tr> 
</form> 
</table></td> 
</tr> 
</table></td> 
NEE> 
</table> 
<table width="550" height="20" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
<td>gnbsp;</td> 
</tr> 
</table> 
<?php 
if(@ $_POST['show find']!=""){ 
$username=trim($ POST['username']); 
$ddh=trim($ POST['ddh']); 
if($username==""){ 
$sql=mysqli query($conn,"select * from tb dingdan where dingdanhao 





show_ find" name="show find"> 
"submit" class="buttoncss" 
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md 
} 
elseif ($ddh==""){ 
$sql=mysqli query($conn,"select * from tb dingdan where xiadanren= 
'",.$username.™'"); 
} 
else{ 
$sql=mysqli query($connv "select * from tb dingdan where xiadanren= 
'".$username."'and dingdanhao='".$ddh."'"); 
} 
$info=mysqli fetch array($sql); 
if ($info==false){ 
echo "<div algin='center'> 对 不 起 ,没有 查找 到 该 订单 !</div>"; 
有 
elsef{ 
> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing= 
2 
<tr> 
<td height="20" bgcolor="#0099FF"><div align="center" style="color: 
#FFFFFF"> 查 询 结 果 </div></td> 
SEE> 
<tr> 
<td height="50" bgcolor="#555555"><table width="550" height="50" 
border="0" align="center" cellpadding="0" cellspacing="1"> 


<tr> 
<td width="77" height="25" bgcolor="#FFFFFF"><div align="center"> 
订单 号 </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 下 单 用 户 
</div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 订 货 人 
</div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 金额 总 计 
</div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 付款 方式 
</div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 收 款 方 式 
</div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 订 单 状态 
</div></td> 
</Er> 
<?php 
dof{ 
?> 
EE 


<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['dingdanhao'];?></div></td> 

<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['xiadanren'];?></div></td> 

<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['shouhuoren'];?></div></td> 

<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['total'];?></div></td> 
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<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['zfff'];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['shff'];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo 
$info['zt'];?></div></td> 
</tr> 
<?php 
}while ($info=mysqli fetch array($sql)); 
?> 
</table></td> 
</tr> 
</table> 
<?php 
} 
} 


?> 
</body> 
</html> 


殴 网 信息 管理 功能 


信息 管理 功能 就 是 指 管理 员 在 网 站 后 台 能 够 实现 对 新 闻 、 用 户 发 布 的 商品 评价 等 一 些 相 关 信 
息 进 行 管理 的 操作 ， 实 例 制作 了 “管理 公告 ” “发 布 公告 ”和 “管理 评价 ”3 个 功能 选项 ， 通 过 这 3 
个 功能 能 够 实现 整个 网 站 的 即时 公告 发 布 、 公 告 修 改 以 及 商品 评论 的 编辑 修改 功能 。 


10.5.1 ”管理 公告 


理 公告 功能 是 指 在 后 台 对 发 布 的 公告 可 以 进行 修改 和 删除 的 操作 ， 实 例 管理 公告 的 主页 为 
Oe 
步 又 014 制作 好 的 admingonggao.php 页 面 效 果 如 图 10-23 所 示 。 


全 bwamppwtdocswshopvedminvadmingongoao php* -Ox 
WD ntcs mp 7 
Ee 

















body -fom 761x168 ~ 图 
图 10-23 管理 公告 admingonggao.php 
步 又 024 选中 “选择 ” 复 选 框 ， 单 击 “ 删 除 所 选 ”按钮 将 表单 提交 到 deletegonggao.php 进 行 
删除 公告 的 操作 ， 代 码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
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include ("conn.php"); 
while(list(S$namevS$value)=each($_POST) ) 
mysqli query($conn,"delete from tb _ gonggao where id='".$value."'"); 


. 
header ("location:admingonggao.php"); 
2 
步骤 034 单 击 “修改 ”文字 链接 ， 可 以 打开 editgonggao.php 页 面 进行 公告 的 编辑 操作 ， 该 页 
面 如 图 10-24 所 示 。 


莉 p ampp\ntdocs\shopadmin\editgonggao php -Ox 
ED nt -os 








wy DD rp 
图 10-24 修改 公告 editgonggao.php 


步骤 044 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ”按钮 可 以 提交 表单 到 
saveeditgonggao.php 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
$title=$ POST['title']; 
$content=$_POST['content']; 
include ("conn.php"); 
mysqli_query ($conn, "update tb _gonggao set title='$title',content='$content' 
where id="'".$ POST['id’']."'"); 
echo "<script>alert (' 公 告 修 改 成 功 !') ;history.back();</script>"; 
?> 


10.5.2 发布 公告 


用 于 添加 新 的 公告 页 面 是 addgonggao.php, 实现 的 方法 就 是 采集 公告 的 字段 进行 数据 的 插入 操 
作 即 可 以 完成 ， 本 小 节 就 介绍 新 添加 公告 的 具体 方法 。 


步 又 014 制作 采集 公告 的 addgonggao.php 页 面 如 图 10-25 所 示 。 
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雷 ovempp\hadocsshopvadminvaddoonooao php -Ox 
绒 克 fontcs 





By i 
图 10-25 addgonggao.php 页 面 的 效果 
步 又 024 录入 完 主题 和 内 容 ， 单 击 “添加 ”按钮 可 以 提交 表单 进行 验证 ， 并 提交 到 
Savenewgonggao.php 页 面 进 行 新 闻 公 告 的 保存 操作 ， 实 现 的 代码 如 下 : 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<?php 
include ("conn.php"); 
$title=$_POST['title']; 
$content=$_POST['content']; 
$time=date ("Y-m-j"); 
mysqli query($conn,"insert into tb gonggao (title,content,time) values 
('$title','$content', '$time')"); 


echo "<script>alert (' 公 告 添加 成 功 !') ;history.back();</script>"; 
?> 


10.5.3 ”管理 评价 


后 台 信 息 管理 的 最 后 一 个 功能 是 “管理 评价 ”功能 ， 通 过 此 功能 可 以 将 商品 的 一 些 负面 信息 
进行 删除 ， 管 理 评价 功能 的 页 面 是 editpinglun.php， 制 作 的 方法 如 下 : 
步 又 014 制作 的 editpinglun.php 页 面 效果 如 图 10-26 所 示 。 


恒 pwampp\tdocsshopvsdminvedipinglun php | 
SR ntcs -mo 
加 


编辑 用 户 评价 





758x165 ~ 加 
图 10-26 编辑 用 户 评价 editpinglun.php 


步 最 024 通过 单 击 “ 查 看 ”文字 链接 能 打开 Windows 窗 口 显 示 评价 的 详细 内 容 ， 实 现 的 代 
码 如 下 : 


<?php 
include ("conn.php"); 
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$sql=mysqli query($conn,"select count (*) as total from tb pingjia "); 
$info=mysqli fetch array($sql); 
$total=$info['total']; 
if($total==0) 
中 
echo "本 站 暂 无 用 户 发 表 评论 !"; 
， 
else 


{ 


?> 
<script language="javascript"> 
function openpj (id) 
‘ 


window.open ("lookpinglun.php?id="+id, "newframe", "width=500,height=300,top=100, 
left=200,menubar=no,toolbar=no, location=no,scrollbar=no, status=no"); 


} 
</script> 


步骤 034 选中 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选项 ”按钮 将 表单 提交 至 删除 评价 的 页 面 
deletepingjia.php， 该 页 面 的 代码 如 下 : 
<?php 
include ("conn.php"); 
while(list ($name, $value)=each($_ POST)) 
{ 
$id=$value; 
mysqli_ query($conn,"delete from tb pingjia where id=".$id.""); 


} 
header ("location:editpinglun.php"); 


?> 





本 章 系 统 地 讲解 了 翡翠 电子 商城 的 后 台 管理 开发 办 法 ， 一 般 的 电子 商城 的 常用 功能 也 无 非 就 
是 这 些 ， 有 些 比 较 复杂 的 结算 系统 如 积分 系统 ， 和 迭代 结算 系统 等 都 是 在 使 用 PHP 的 运算 函数 基础 上 
使 用 客户 提供 的 结算 运算 公式 去 实现 的 。 读者 可 以 触 类 旁 通 , 举一反三 , 在 掌握 本 系统 开发 方法 的 
基础 上 做 更 多 的 需求 开发 ， 真 正成 为 PHP 高 级 程序 员 。 
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